Cookie、localStorage、sessionStorage

本文参考了以下视频

  1. cookie、localStorage 和 sessionStorage的区别及应用实例
  2. 浏览器本地存储

Cookie是一种存储机制
HTTP Cookie(也叫 Web Cookie 或浏览器 Cookie)是服务器发送到用户浏览器并保存在本地的一小块数据(一般不超过4kb)。浏览器会存储 cookie 并在下次向同一服务器再发起请求时携带并发送到服务器上。通常,它用于告知服务端请求是否来自同一浏览器——如保持用户的登录状态。Cookie 使基于无状态的 HTTP 协议记录稳定的状态信息成为了可能。image
浏览器查看位置image
如果没有设置HttpOnly,则可以直接通过JS读取Cookie(document.cookie),Cookie是字符串,格式为"key1=value1; key2=value2; ...",多个键值对之间以分号空格"; "的形式隔开image

比如在用户下次登录时,浏览器会根据Cookie自动填充用户名。如下是这个过程的简单实现image

Window.localStorage和Window.sessionStorage

localStorage对象和sessionStorage对象都是HTML5的新特性之一。键值对总是以字符串的形式存储image
localStorage和sessionStorage都有setItem('key', 'value'),getItem('key'),removeItem('key'),clear()方法
以sessionStorage为例

// 保存数据到 sessionStorage
sessionStorage.setItem('key', 'value');

// 从 sessionStorage 获取数据
let data = sessionStorage.getItem('key');

// 从 sessionStorage 删除保存的数据
sessionStorage.removeItem('key');

// 从 sessionStorage 删除所有保存的数据
sessionStorage.clear();

因为键值对总是以字符串的形式存储注意

  1. 存储在 sessionStorage 或 localStorage 中的数据特定于页面的协议。也就 是说 http://example.comhttps://example.com 的 sessionStorage/localStorage 相互隔离。
  2. 被存储的键值对总是以 UTF-16 DOMString 的格式所存储,其使用两个字节来表示一个字符。所以数值,复杂数据类型(对象,数组等)的数据会自动转换成字符串形式。
    若不想让复杂数据类型被转成字符串而造成数据丢失,比如对象类型的数据会转换成[object Object],可以在存储的时候用JSON.stringify()将其转换成JSON字符串,用的时候再JSON.parse()恢复

localStorage

存储在 localStorage 的数据可以长期保留(存储在计算机硬盘中),

关机后再用同一浏览器打开以前登录过的页面仍能保持登录状态,这就是利用了localStorage。但是用另一浏览器打开同一网站(前提是该浏览器以前未登录过该网站),却不能保持登录状态,是因为不同浏览器存放localStorage数据的地方不是同一个地方
以下简单地模拟了利用localStorage保存历史上搜索过的数据,sessionStorage也能实现这样的功能,把以下代码中的localStorage换成sessionStorage就好啦image

sessionStorage

当页面被关闭时,存储在 sessionStorage 的数据会被清除。

  • 页面会话在浏览器打开期间一直保持,并且重新加载或恢复页面仍会保持原来的页面会话。
  • 在新标签或窗口打开一个页面时会复制顶级浏览会话的上下文作为新会话的上下文,这点和 session cookie 的运行方式不同。
  • 打开多个相同的 URL 的 Tabs 页面,会创建各自的 sessionStorage。
  • 关闭对应浏览器标签或窗口,会清除对应的 sessionStorage。

以下是Cookie、localStorage、sessionStorage间的对比image
由于cookie是与请求一起发送的,而localStorage、sessionStorage是存在本地,所以cookie体积比localStorage
、sessionStorage小得多

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CookieLocalStorageSessionStorage是在Web开发中常用的存储数据的方式。 Cookie是一种存储在用户计算机上的小型文本文件,由服务器通过HTTP响应发送给浏览器,浏览器会将Cookie保存,并在后续的请求中通过HTTP头部发送给服务器。Cookie可以用来存储少量的数据,例如用户的身份认证信息、用户的偏好设置等。由于存储在客户端,因此可以在不同的会话之间持久保存。 LocalStorageSessionStorage是HTML5中新增的Web存储接口,都是在浏览器端进行数据存储的方式,不需要与服务器进行交互。它们使用相似的API,都可以存储大量的数据,并且保存在浏览器的本地环境中。 LocalStorageSessionStorage之间的主要区别在于数据的生命周期和作用域。LocalStorage保存的数据没有过期时间,除非用户手动删除,否则数据会一直保留。而SessionStorage保存的数据只在当前会话中有效,当用户关闭浏览器窗口或标签页时,数据会被清除。另外,LocalStorage的数据可以在同一个域名下的不同页面间共享,而SessionStorage的数据只能在同一个页面中共享。 总结: - Cookie是在服务器和浏览器之间传递的存储方式,用于存储少量数据。 - LocalStorageSessionStorage是在浏览器端进行数据存储的方式,可以保存大量数据。 - LocalStorage的数据没有过期时间,而SessionStorage的数据在会话结束时被清除。 - LocalStorage的数据可以在同一个域名下的不同页面间共享,而SessionStorage的数据只在同一个页面中有效。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值