localStorage sessionStorage Cookie 区别和用法
程序员文章站
2022-06-10 12:50:03
...
原文:
https://blog.csdn.net/shenxianhui1995/article/details/93010158
区别
localStorage: localStorage 的生命周期是永久的,关闭页面或浏览器之后 localStorage 中的数据也不会消失。localStorage 除非主动删除数据,否则数据永远不会消失sessionStorage: sessionStorage 的生命周期是仅在当前会话下有效。sessionStorage 引入了一个“浏览器窗口”的概念,sessionStorage 是在同源的窗口中始终存在的数据。只要这个浏览器窗口没有关闭,即使刷新页面或者进入同源另一个页面,数据依然存在。但是 sessionStorage 在关闭了浏览器窗口后就会被销毁。同时独立的打开同一个窗口同一个页面,sessionStorage 也是不一样的
cookie: cookie生命期为只在设置的cookie过期时间之前一直有效,即使窗口或浏览器关闭。 存放数据大小为4K左右, 有个数限制(各浏览器不同),一般不能超过20个。缺点是不能储存大数据且不易读取
建议
由于 vue 是单页面应用,操作都是在一个页面跳转路由,因此 sessionStorage 较为合适
原因:
- sessionStorage 可以保证打开页面时 sessionStorage 的数据为空
- 每次打开页面 localStorage 存储着上一次打开页面的数据,因此需要清空之前的数据
用法
一. localstorage 和 sessionstorage
- 首先要判断浏览器是否支持 localStorage / sessionStorage
比如判断 localStorage
-
if (window.localStorage) {
-
alert('浏览支持 localStorage');
-
} else {
-
alert('浏览暂不支持 localStorage');
-
}
- 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();
二. cookie
- 储存数据
window.document.cookie = 'xxx';
- 取出数据
document.cookie
</div>
</div>
推荐阅读
-
powerpoint2003官方下载免费完整版 php中理解print EOT分界符和echo EOT的用法区别小结
-
for,foreach,iterator的用法和区别
-
require.include.require_once.include_once的用法和区别_PHP教程
-
Java中CyclicBarrier和CountDownLatch的用法与区别
-
浅谈COOKIE和SESSION区别_PHP
-
COOKIE和SESSION关系和区别等,cookiesession区别
-
PHP中cookie和session的区别实例分析_php实例
-
详解PHP中cookie和session的区别及cookie和session用法小结,cookiesession
-
php:switch case 和 if else 的用法区别及运行效率详解
-
php中全等===和相等==的用法区别