Cookie、localStorage 和 sessionStorage 的区别及应用实例
在前端开发中,持久化数据存储是一个非常常见的需求。为了实现这一点,浏览器提供了多种方式,包括 Cookie、localStorage 和 sessionStorage。这三者各有优劣,适用于不同的场景
1. Cookie
Cookie 是浏览器存储少量数据的一种机制,通常由服务器生成并发送到客户端。每次客户端向同一域名发起请求时,Cookie 都会自动附带在请求头中发送到服务器。
如图所示:

特点:
- 数据大小限制:单个 Cookie 的数据大小限制通常在 4KB 左右。
- 生命周期:Cookie 可以设置
expires或max-age属性来控制其有效期,默认情况下,Cookie 会在会话结束(即浏览器关闭)后删除。 - 作用域:Cookie 与特定的域名和路径关联,可以通过设置
domain和path来控制它的作用范围。 - 安全性:可以通过
Secure标记仅允许在 HTTPS 连接中传输 Cookie,还可以通过HttpOnly标记使 Cookie 无法被 JavaScript 访问,增加安全性。
应用场景:
- 会话管理:例如,登录状态的保持。
- 用户偏好:例如,保存用户的语言设置。
- 跟踪用户行为:例如,第三方分析工具使用 Cookie 进行用户跟踪。
示例:
// 设置一个 Cookie
document.cookie = "username=John; expires=Fri, 31 Dec 2024 23:59:59 GMT; path=/"; // 读取 Cookie
const cookies = document.cookie.split("; ");
cookies.forEach(cookie => {
const [key, value] = cookie.split("=");
console.log(`${key}: ${value}`);
}); // 删除 Cookie
document.cookie = "username=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/";
2. localStorage
localStorage 是 HTML5 引入的一种 Web 存储机制,用于持久化保存客户端数据。它的存储是基于键值对的,并且不同域名的 localStorage 是独立的。

特点:
- 数据大小限制:通常为 5MB。
- 生命周期:localStorage 中的数据没有过期时间,除非手动删除,否则数据会一直存在。
- 作用域:localStorage 只能在同一域名下的所有页面共享。
应用场景:
- 长期保存的数据:例如,用户的设置、主题选择等不需要频繁更改的数据。
- 离线 Web 应用:可以用于保存用户在离线时生成的数据。
示例:
// 设置数据
localStorage.setItem('theme', 'dark'); // 读取数据
const theme = localStorage.getItem('theme');
console.log(theme); // 输出 'dark' // 删除数据
localStorage.removeItem('theme'); // 清空所有数据
localStorage.clear();
3. sessionStorage
sessionStorage 也是 HTML5 引入的 Web 存储机制,与 localStorage 类似,但它的生命周期仅限于浏览器会话期间。关闭浏览器标签页或窗口后,sessionStorage 中的数据就会被清除。
特点:
- 数据大小限制:通常为 5MB。
- 生命周期:数据在页面会话期间有效,页面关闭后数据即被删除。
- 作用域:sessionStorage 只能在同一窗口或标签页中共享,不同的窗口或标签页之间的数据互不影响。
应用场景:
- 临时保存的数据:例如,表单数据的临时保存,以防止页面刷新导致的数据丢失。
- 页面间的数据传递:例如,在多步表单中,传递各步之间的数据。
示例:
// 设置数据
sessionStorage.setItem('sessionData', 'temporaryData'); // 读取数据
const data = sessionStorage.getItem('sessionData');
console.log(data); // 输出 'temporaryData' // 删除数据
sessionStorage.removeItem('sessionData'); // 清空所有数据
sessionStorage.clear();
4. 区别总结:
| 特性 | Cookie | localStorage | sessionStorage |
|---|---|---|---|
| 数据大小限制 | 约 4KB | 约 5MB | 约 5MB |
| 生命周期 | 可设置过期时间 | 持久保存,除非手动删除 | 仅在页面会话期间有效 |
| 作用域 | 与域名、路径相关联 | 同一域名下的所有页面共享 | 仅在同一窗口或标签页中共享 |
| 是否随请求发送 | 每次请求都会自动附带发送 | 否 | 否 |
| 常见应用场景 | 会话管理、用户偏好、跟踪用户 | 长期保存的数据、离线 Web 应用 | 临时保存的数据、页面间数据传递 |
PS:图片来源于B站技术蛋老师,侵删
Cookie、localStorage 和 sessionStorage 的区别及应用实例的更多相关文章
- cookie,localStorage和sessionStorage的区别
cookie已经很久没有用过了,一直觉得session Storage和local Storage更加好用一些.
- cookie、session、localStorage、sessionStorage的区别
cookie的机制 cookie是存储在用户本地终端上的数据.有时也用cookies,指某些网站为了辨别用户身份,进行session跟踪而存储在本地终端上的数据,通常经过加密. Cookie是服务器发 ...
- Cookie, LocalStorage 与 SessionStorage
Cookie, LocalStorage 与 SessionStorage相同点 都是储存在用户本地的数据. 意义在于避免数据在浏览器和服务器间不必要地来回传递. 三者的特点 同属于html5 ...
- localStorage和sessionStorage的区别
//在chrome测试的结果; 知识点1:localStorage和sessionStorage的区别; localStorage生命周期是永久,这意味着除非用户显示在浏览器提供的UI上清除local ...
- 区分 Cookie, LocalStorage 与 SessionStorage
基本概念 Cookie Cookie 的大小限制为4KB左右,是网景公司的前雇员 Lou Montulli 在1993年3月的发明.它的主要用途有保存登录信息,比如你登录某个网站市场可以看到“记住密码 ...
- vuex知识笔记,及与localStorage和sessionStorage的区别
菜单快捷导航 Vuex是什么东东,有什么应用场景?localStorage和sessionStorage能否替代它? Vuex知识点State.Getter.Mutaion.Action Vuex模块 ...
- cookie、LocalStorage、sessionStorage三者区别以及使用方式
cookie用来保存客户浏览器请求服务器页面的请求信息 HTML5的WebStorage提供了两种API:localStorage(本地存储)和sessionStorage(会话存储) WebStor ...
- cookie、localStorage、sessionStorage的区别
localStorage - 没有时间限制的数据存储 sessionStorage - 针对一个 session 的数据存储 共同点:sessionStorage.localStorage和cooki ...
- Cookie、LocalStorage 与 SessionStorage的区别在哪里?
基本概念 Cookie Cookie 是小甜饼的意思.顾名思义,cookie 确实非常小,它的大小限制为4KB左右.它的主要用途有保存登录信息,比如你登录某个网站市场可以看到“记住密码”,这通常就是通 ...
- cookie,localStorage和sessionStorage区别
三者的异同 特性 Cookie localStorage sessionStorage 数据的生命期 一般由服务器生成,可设置失效时间.如果在浏览器端生成Cookie,默认是关闭浏览器后失效 除非被清 ...
随机推荐
- HTML5画布-小球碰撞
Tips:当你看到这个提示的时候,说明当前的文章是由原emlog博客系统搬迁至此的,文章发布时间已过于久远,编排和内容不一定完整,还请谅解` HTML5画布-小球碰撞 日期:2017-7-18 阿珏 ...
- ELKF(elasticsearch、logstash、kibana、filebeat)搭建及收集nginx日志
1.elasticsearch 1.1.根目录下新建data文件夹 1.2.修改elasticsearch.yml文件,添加以下内容 path.data: /home/wwq/elk/elastics ...
- mac brew install Error: No available formula with the name “*“的解决办法
背景 在mac上使用brew安装软件发生错误 解决办法 执行以下命令即可 rm -rf /usr/local/Homebrew/Library/Taps/homebrew/homebrew-core ...
- VMware 17 Exception 0xc0000094 解决
VMWare16的虚拟机升级到17时, 可能会出现虚拟机可以正常使用, 但编辑设置就会出现vmui错误的现像. VMware Workstation unrecoverable error: (vmu ...
- Spring的IOC容器类别概述
Spring的IOC该如何理解呢? 平常在一个方法当中,若要用到外部另一个类里的非静态方法,首先,需要先通过new一个对象,再根据这个对象去调用其方法.若只需要一两个对象还好,一旦涉及的外部对象多了, ...
- MyBatis-Plus 整理
# 前言 代码生成器插件选择去这里:https://www.cnblogs.com/zixq/p/16726534.html 相关插件在那里面已经提到了 # 上手 MyBatis-Plus 是一个 M ...
- webgl(threejs)生成房间楼层
楔子 在很多数字孪生项目中,都会涉及到楼层的建模.楼层的建模由于结构繁多,如果都是建模师进行手动建模,工作量会比较大.而楼层本身的结构,可以抽象成可以通过路径构造的对象(这和之前的文章提及的的管路以及 ...
- 论如何直接用EF Core实现创建更新时间、用户审计,自动化乐观并发、软删除和树形查询(上)
前言 数据库并发,数据审计和软删除一直是数据持久化方面的经典问题.早些时候,这些工作需要手写复杂的SQL或者通过存储过程和触发器实现.手写复杂SQL对软件可维护性构成了相当大的挑战,随着SQL字数的变 ...
- Bash 技巧
Bash 使用技巧 Bash 是 GNU 项目的 Bourne Again SHell, 具有交互式命令行编辑.支持它的体系结构上的作业控制.类似 csh 的功能 Bash 是免费软件,根据 GNU ...
- Nuxt 使用指南:掌握 useNuxtApp 和运行时上下文
title: Nuxt 使用指南:掌握 useNuxtApp 和运行时上下文 date: 2024/7/21 updated: 2024/7/21 author: cmdragon excerpt: ...