一 什么是localStorage
对浏览器来说,使用 Web Storage 存储键值对比存储 Cookie 方式更直观,而且容量更大,它包含两种:localStorage 和 sessionStorage
-
sessionStorage(临时存储) :为每一个数据源维持一个存储区域,在浏览器打开期间存在,包括页面重新加载
-
localStorage(长期存储) :与 sessionStorage 一样,但是浏览器关闭后,数据依然会一直存在
所以上次使用cookie的时候就遇到了一个坑,设置后马上访问session会获取不到,蛋疼,还需要刷新一下,原因是:
二 使用方法
注意:sessionStorage 和 localStorage 的用法基本一致,引用类型的值要转换成JSON,所以这里就只列举localStorage
1 保存
1
2
3
4
5
6
7
8
9
10
11
12
13
|
//对象
const info = { name:
'hou'
, age: 24, id:
'001'
};
//字符串
const str=
"haha"
;
localStorage.setItem(
'hou'
, JSON.stringify(info));
localStorage.setItem(
'zheng'
, str);
|
2 获取
1
2
3
|
var
data1 = JSON.parse(localStorage.getItem(
'hou'
));
var
data2 = localStorage.getItem(
'zheng'
);
|
3 删除
1
2
3
4
5
|
//删除某个
localStorage.removeItem(
'hou'
);
//删除所有
localStorage.clear();
|
4 监听
1
2
3
4
5
|
Storage 发生变化(增加、更新、删除)时的 触发,同一个页面发生的改变不会触发,只会监听同一域名下其他页面改变 Storage
window.addEventListener(
'storage'
,
function
(e) {
console.log(
'key'
, e.key); console.log(
'oldValue'
, e.oldValue);
console.log(
'newValue'
, e.newValue); console.log(
'url'
, e.url);
})
|
5浏览器中查看

6 vue中实践
根据我的需求来的一个默认记住上次选择的,很简单
添加数据的时候,下次添加默认记住我上次的选择
所以,在添加或者提交的时候存储值即可,
1
2
3
4
5
6
7
8
9
10
|
//记住上次选中的审核人
if
(localStorage.length>0){
var
mydata = localStorage.getItem(
'projectId'
);
if
(mydata!=
null
){
var
arr3=mydata.split(
","
);
if
(arr3[0]==me.workhourData.projectId){
me.workhourData.projectManager=arr3[1];
}
}
}
|
7 注意点
localStorage有效期是永久的。一般的浏览器能存储的是5MB左右。sessionStorage api与localStorage相同。
sessionStorage默认的有效期是浏览器的会话时间(也就是说标签页关闭后就消失了)。
localStorage作用域是协议、主机名、端口。(理论上,不人为的删除,一直存在设备中)
sessionStorage作用域是窗口、协议、主机名、端口。
知道了这些知识点后,你的问题就很好解决了。
localStorage是window上的。所以不需要写this.localStorage,vue中如果写this,是指vue实例。会报错