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


Posted in Javascript onNovember 16, 2020

一 什么是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 监听

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浏览器中查看

Vue基于localStorage存储信息代码实例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实例。会报错

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript 定时器调用传递参数的方法
Nov 12 Javascript
javascript获取元素偏移量的方法有哪些
Jun 24 Javascript
jQuery中:selected选择器用法实例
Jan 04 Javascript
Javascript中拼接大量字符串的方法
Feb 05 Javascript
移动端翻页插件dropload.js(支持Zepto和jQuery)
Jul 27 Javascript
Vue.js教程之计算属性
Nov 11 Javascript
解决vue中虚拟dom,无法实时更新的问题
Sep 15 Javascript
Vue中控制v-for循环次数的实现方法
Sep 26 Javascript
vue项目首屏加载时间优化实战
Apr 23 Javascript
浅谈vue在html中出现{{}}的原因及解决方式
Nov 16 Javascript
交互式可视化js库gojs使用介绍及技巧
Feb 18 Javascript
vue中的可拖拽宽度div的实现示例
Apr 08 Vue.js
微信小程序自定义底部弹出框动画
Nov 18 #Javascript
vue 封装面包屑组件教程
Nov 16 #Javascript
Vue使用路由钩子拦截器beforeEach和afterEach监听路由
Nov 16 #Javascript
小程序实现密码输入框
Nov 16 #Javascript
vue 使用localstorage实现面包屑的操作
Nov 16 #Javascript
适用于 Vue 的播放器组件Vue-Video-Player操作
Nov 16 #Javascript
Vue中使用JsonView来展示Json树的实例代码
Nov 16 #Javascript
You might like
php的计数器程序
2006/10/09 PHP
屏蔽浏览器缓存另类方法
2006/10/09 PHP
基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码
2015/08/25 PHP
表单内同名元素的控制
2006/11/22 Javascript
js 解决“options为空或不是对象”
2008/12/22 Javascript
javascript 同时在IE和FireFox获取KeyCode的代码
2010/02/07 Javascript
js操作iframe兼容各种主流浏览器示例代码
2013/07/22 Javascript
JS对象转换为Jquery对象示例
2014/01/26 Javascript
js实现字符串的16进制编码不加密
2014/04/25 Javascript
jQuery前端框架easyui使用Dialog时bug处理
2014/12/05 Javascript
JS结合bootstrap实现基本的增删改查功能
2016/07/22 Javascript
AngularJS基础 ng-cut 指令介绍及简单示例
2016/08/01 Javascript
JavaScript面向对象编写购物车功能
2016/08/19 Javascript
NodeJs的fs读写删除移动监听
2017/04/28 NodeJs
vue 左滑删除功能的示例代码
2019/01/28 Javascript
对Layer UI 模块化的用法详解
2019/09/26 Javascript
微信小程序实现多选框全选与反全选及购物车中删除选中的商品功能
2019/12/17 Javascript
微信小程序静默登录的实现代码
2020/01/08 Javascript
详解Webpack4多页应用打包方案
2020/07/16 Javascript
[01:06:43]完美世界DOTA2联赛PWL S3 PXG vs GXR 第二场 12.19
2020/12/24 DOTA
python使用内存zipfile对象在内存中打包文件示例
2014/04/30 Python
Python 检查数组元素是否存在类似PHP isset()方法
2014/10/14 Python
Python框架Flask的基本数据库操作方法分析
2018/07/13 Python
Python判断对象是否为文件对象(file object)的三种方法示例
2019/04/26 Python
如何使用Flask-Migrate拓展数据库表结构
2019/07/24 Python
Python while true实现爬虫定时任务
2020/06/08 Python
Python Selenium模块安装使用教程详解
2020/07/09 Python
某同学的自我鉴定范文
2013/12/26 职场文书
小型女装店的创业计划书
2014/01/09 职场文书
协议书格式
2014/04/23 职场文书
服务承诺口号
2014/05/22 职场文书
综合测评个人总结
2015/03/03 职场文书
新郎婚礼致辞
2015/07/27 职场文书
解决golang 关于全局变量的坑
2021/05/06 Golang
Python使用openpyxl批量处理数据
2021/06/23 Python
python中pycryto实现数据加密
2022/04/29 Python