Vue总结第一篇

Vue使用vuex和localStorage

首先说一下vuex和localStorage的区别

1.实质区别

vuex存的是状态,存储在内存;localStorage是浏览器提供的接口,让你存的是接口,以文件的形式存到本地

2.应用场景

vuex用于组件之间传值,localStorage主要用于页面间传值

3.永久性

当刷新页面时,vuex存储的值会丢失,localStorage不会

总结

localStorage可以代替vuex,对于不变的数据确实可以,但是当两个组件共同用以数据源,如果其中一个组件中的数据源改变,希望另一个组件响应变化,这时候就要选择用vuex。vuex是vue的状态管理机制,是方便组件之间通信的。一个组件的数据变化是会映射到使用这个数据的其他组件。而localStorage是本地存储,是将数据存储到浏览器的方法,一般在跨页面时使用。

一、localStorage的使用
1.什么是localStorage

对浏览器来说,使用 Web Storage 存储键值对比存储 Cookie 方式更直观,而且容量更大,它包含两种:localStorage 和 sessionStorage

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

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

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

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

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

2.使用方法

sessionStorage 和 localStorage 的用法基本一致,引用类型的值要转换成JSON,所以这里就只列举localStorage

1.保存

// 对象
              const info = { name:'制度',collect:'10',id:'001' };
              // 字符串
              const str = 'qqqq';
 
              localStorage.setItem('item', JSON.stringify(info));
              localStorage.setItem('itemStr',str);
2.获取

var data1 = JSON.parse(localStorage.getItem('item'));
var data2 = JSON.getItem('itemStr');
3.删除

 // 删除某个
localStorage.removeItem('item');
// 删除所有
localStorage.clear();
4.监听

// 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.注意

localStorage有效期是永久的。一般的浏览器能存储的是5MB左右。sessionStorage api与localStorage相同。
sessionStorage默认的有效期是浏览器的会话时间(也就是说标签页关闭后就消失了)。
localStorage作用域是协议、主机名、端口。(理论上,不人为的删除,一直存在设备中)
sessionStorage作用域是窗口、协议、主机名、端口。
localStorage是window上的。所以不需要写this.localStorage,vue中如果写this,是指vue实例。会报错

###转载自CSDN博主「米儿web」的原创文章:https://blog.csdn.net/qq_24767091/article/details/104790375
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 使用的是vue-cli 2.x脚手架 一、头部组件的实现 二、使用vue-router实现选项卡 项目的地址: 一...
    小伙子太认真阅读 2,138评论 7 11
  • Vue真是太好了 壹万多字的Vue知识点 超详细! 9 ️1⃣️、Vue和其他两大框架的区别 Angular 学习...
    三千繁夢阅读 352评论 0 0
  • 由于简书没有目录的功能,为了更加清晰的学习,我制作了一个目录地址如下:学习Vue目录 链接地址: https:/...
    读书的鱼阅读 10,114评论 13 249
  • 生命周期函数面试题 1.什么是Vue生命周期?vue生命周期是指vue是对象从创建到销毁的过程。 2.Vue生命周...
    Angel_6c4e阅读 16,738评论 2 51
  • 我是黑夜里大雨纷飞的人啊 1 “又到一年六月,有人笑有人哭,有人欢乐有人忧愁,有人惊喜有人失落,有的觉得收获满满有...
    陌忘宇阅读 8,595评论 28 53