vue中使用localStorage存储信息的使用方法(详解)


一、什么是localStorage

JSON.parse()作用是将字符串转化成json数组,JSON.stringify()作用是将json数组转换成字符串
对浏览器来说,使用Web Storage存储键值对比存储Cookie方式更直观,而且容量更大,它包含两种:localStorage和sessionStorage

  1. sessionStorage(临时存储):为每一个数据源维持一个存储区域,在浏览器打开期间存在,包括页面重新加载
  2. loalStorage(长期储存):与sessionStorage一样,但是浏览器关闭后,数据依然会一直存在

所以上次使用cookie的时候就遇到了一个坑,设置后马上访问session会获取不到,蛋痛,还需要刷新一下,原因是:
当我们首次访问设置Cookie的页面是,服务器会把设置的Cookie值通过响应头送过来,告诉浏览器将cookie存储的本地相应文件夹中(注意:第一次访问时本地还没有存储Cookie,所以此时获取不到值);
当第二次访问时(或是进行cookie设置后,过期前所有的访问)时,请求头信息中你都会把Cookie值携带。

二、使用方法

  • 注意:sessionStorage和localStorage的用法基本一致,引用类型的值要转换成JSON,所以这里就之列举localStorage
1.保存
//对象
const info = {name: "huo", age: 18,id: "1"}
//字符串
const str = "haha";

localStorage.setItem('huo',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.监听
//Storage 发生变化(增加、更新、删除)时的 触发,同一个页面发生的改变不会触发,只会监听同一域名下其他页面改变
 Storagewindow.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中实践

根据我的需求来的一个默认记住上次选择的,很简单,
添加数据的时候,下次添加默认记住我上次的选择,
所以,在添加或者提交的时候存储值即可,

localStorage.setItem('projectId',me.workhourData.projectId+","+me.workhourData.projectManager);
在打开新建页面的时候获取一下就好了,只需要判断非空就行

//记住上次选中的审核人
            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实例。会报错



使用时有两点需要注意过的地方:

. localStorage在浏览器的隐私模式下面是不可读取的。

. localStorage本质上是对字符串的读取,有json格式时需要JSON.stringify()转化为字符串。

. localStorage不能被爬虫抓取


链接: https://cloud.tencent.com/developer/article/1372576


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM