localStorage、sessionStorage、Cookie区别及用法

本文对比了localStorage、sessionStorage和Cookie在生命周期、数据大小和应用场景上的差异,特别强调了sessionStorage在单页应用中的优势,并提供了操作方法和使用场景实例。
摘要由CSDN通过智能技术生成


一、区别

1、localStorage: localStorage 的生命周期是永久的,关闭页面或浏览器之后 localStorage 中的数据也不会消失。localStorage 除非主动删除数据,否则数据永远不会消失

2、sessionStorage: sessionStorage 的生命周期是仅在当前会话下有效。sessionStorage 引入了一个“浏览器窗口”的概念,sessionStorage 是在同源的窗口中始终存在的数据。只要这个浏览器窗口没有关闭,即使刷新页面或者进入同源另一个页面,数据依然存在。但是 sessionStorage 在关闭了浏览器窗口后就会被销毁。同时独立的打开同一个窗口同一个页面,sessionStorage 也是不一样的

3、cookie: cookie生命期为只在设置的cookie过期时间之前一直有效,即使窗口或浏览器关闭。 存放数据大小为4K左右, 有个数限制(各浏览器不同),一般不能超过20个。缺点是不能储存大数据且不易读取

二、建议

由于 vue 是单页面应用,操作都是在一个页面跳转路由,因此 sessionStorage 较为合适,原因:

  • sessionStorage 可以保证打开页面时 sessionStorage 的数据为空
  • 每次打开页面 localStorage 存储着上一次打开页面的数据,因此需要清空之前的数据

三、用法

1. localstorage 和 sessionstorage

1、首先要判断浏览器是否支持 localStorage / sessionStorage,比如判断 localStorage

if (window.localStorage) {
    alert('浏览支持 localStorage');
} else {
    alert('浏览暂不支持 localStorage');
}

2、localStorage 和 sessionStorage 都具有相同的操作方法,例如 setItem()、getItem() 和 removeItem() 等

  • 储存数据
    用途: 将 value 存储到 key 字段
    用法: setItem( key, value)
    代码示例
sessionStorage.setItem('key', 'value');
localStorage.setItem('key', 'value');
  • 取出数据
    用途: 获取指定 key 本地存储的值
    用法: getItem(key)
    代码示例
sessionStorage.getItem('key');
localStorage.getItem('key');
  • 修改数据
    用途: 修改指定 key 本地存储的值
    用法: setItem(key)
    代码示例
sessionStorage.setItem('key', 'newVal');
localStorage.setItem('key', 'newVal');
  • 删除数据
    用途: 删除指定 key 本地存储的值
    用法: getItem(key)
    代码示例
sessionStorage.removeItem('key');
localStorage.removeItem('key');
  • 清除数据
    用途: 清除所有本地存储的数据
    用法: clear()
    代码示例
sessionStorage.clear();
localStorage.clear();

2、cookie

  • 储存数据
window.document.cookie = 'xxx';

  • 取出数据
document.cookie

本文参考百度,整理所得

localStoragesessionStoragecookie都是在Web开发中用于在浏览器端存储数据的机制。 localStorage是一种持久化存储机制,数据会一直保存在浏览器中,直到被显式清除或通过代码删除。存储在localStorage中的数据可以跨会话和页面保持不变,即使浏览器关闭和重新打开也不会丢失。localStorage只能通过JavaScript访问,它提供了setItem、getItem和removeItem等方法来操作存储的数据。 sessionStorage也是一种存储数据的机制,但与localStorage不同的是,存储在sessionStorage中的数据仅在当前会话(当前标签页或窗口)中有效。当会话结束(标签页或窗口关闭)时,存储在sessionStorage中的数据就会被清除。sessionStorage的使用方法和localStorage相似,也是通过setItem、getItem和removeItem等方法来操作数据。 cookie是一种在浏览器和服务器之间传递的小型文本文件,用于存储会话相关的信息。与localStoragesessionStorage不同,cookie的数据会随着每个HTTP请求发送到服务器端,并且可以设置过期时间。由于cookie会在每个请求中传输,所以存储在cookie中的数据大小有限制(通常为几KB)。可以使用JavaScript或服务器端语言来设置和读取cookie。 总结:localStoragesessionStorage主要用于在浏览器端持久化存储数据,而cookie主要用于在浏览器和服务器之间传递会话相关的信息。具体使用哪种机制取决于实际需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值