当前位置: 移动技术网 > IT编程>开发语言>JavaScript > Vue基于localStorage存储信息代码实例

Vue基于localStorage存储信息代码实例

2020年11月19日  | 移动技术网IT编程  | 我要评论
一 什么是localstorage对浏览器来说,使用 web storage 存储键值对比存储 cookie 方式更直观,而且容量更大,它包含两种:localstorage 和 sessionstor

一 什么是localstorage

对浏览器来说,使用 web storage 存储键值对比存储 cookie 方式更直观,而且容量更大,它包含两种:localstorage 和 sessionstorage

sessionstorage(临时存储) :为每一个数据源维持一个存储区域,在浏览器打开期间存在,包括页面重新加载

localstorage(长期存储) :与 sessionstorage 一样,但是浏览器关闭后,数据依然会一直存在

所以上次使用cookie的时候就遇到了一个坑,设置后马上访问session会获取不到,蛋疼,还需要刷新一下,原因是:

当我们首次访问设置cookie的页面时,服务器会把设置的cookie值通过响应头发送过来,告诉浏览器将cookie存储的本地相应文件夹中(注意:第一次访问时本地还没有存储cookie,所以此时获取不到值);

当第二次访问(或在进行cookie设置后,过期前所有的访问)时,请求头信息你中都会把cookie值携带。(百度到的,暂时还没理解透彻,先搬过来).二 使用方法

注意:sessionstorage 和 localstorage 的用法基本一致,引用类型的值要转换成json,所以这里就只列举localstorage

1 保存

//对象
const info = { name: 'hou', age: 24, id: '001' };
//字符串
const str="haha";
localstorage.setitem('hou', json.stringify(info));
localstorage.setitem('zheng', str);

2 获取

var data1 = json.parse(localstorage.getitem('hou'));
var data2 = localstorage.getitem('zheng'); 

3 删除

//删除某个
localstorage.removeitem('hou');
//删除所有
localstorage.clear();

4 监听

5浏览器中查看

6

vue中实践

根据我的需求来的一个默认记住上次选择的,很简单

添加数据的时候,下次添加默认记住我上次的选择

所以,在添加或者提交的时候存储值即可,

localstorage.setitem('projectid',me.workhourdata.projectid+","+me.workhourdata.projectmanager);在打开新建页面的时候获取一下就好了,只需要判断非空就行

7 注意点

  • localstorage有效期是永久的。一般的浏览器能存储的是5mb左右。sessionstorage api与localstorage相同。
  • sessionstorage默认的有效期是浏览器的会话时间(也就是说标签页关闭后就消失了)。
  • localstorage作用域是协议、主机名、端口。(理论上,不人为的删除,一直存在设备中)
  • sessionstorage作用域是窗口、协议、主机名、端口。

知道了这些知识点后,你的问题就很好解决了。
localstorage是window上的。所以不需要写this.localstorage,vue中如果写this,是指vue实例。会报错

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网