一 什么是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浏览器中查看

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实例。会报错

vue保存页面的值_vue中使用localStorage存储信息相关推荐

  1. vue保存页面的值_vue前端页面跳转参数传递及存储

    不同页面间进行参数传递,实现方式有很多种,最简单最直接的方式就是在页面跳转时通过路由传递参数,如下所示. 路由传递参数 this.$router.push({ name: '跳入页面', params ...

  2. vue打印props的值_vue中props传值方法

    vue中props传值方法 1.开发环境 vue 2.电脑系统 windows10专业版 3.在使用 vue开发的过程中,我们经常会使用 props进行组件的传值,下面是我的分享,希望对你有所帮助! ...

  3. vue设置页面滚动高度_vue中获取滚动高度或指定滚动到某位置

    1.点击某个标签,滚动到某个具体位置 switchHeight(num) { this.selectNum = num; if (num == 0) { document.getElementById ...

  4. VUE保存页面的数据,VUE页面显示就执行某个函数,VUE页面隐藏就执行某个函数

    用 VUE 默认的 keep-alive 组件实现 保存页面的数据,页面显示就执行某个函数,页面隐藏就执行某个函数实现方式: 1.在路由内设置页面是否需要缓存: 示例代码:(在需要的组件里面添加met ...

  5. vue获取input的属性_Vue中自动获取input焦点

    1.给input属性添加autofocus属性,缺点autofocus 在移动版 Safari 上不工作 2.Vue官网给出的解决办法 // 注册一个全局自定义指令 `v-focus` Vue.dir ...

  6. vue实现页面权限显示_Vue 实现前端权限控制

    登录&&权限流程图 前言 首先我们确定的权限控制分为三大部分,其中根据粒度大小分的更细: 登录权限控制 页面权限控制 菜单中的页面是否可以被访问 页面中的按钮 (增.删.改.查)的权限 ...

  7. vue设置页面滚动高度_vue 解决无法设置滚动位置的问题

    问题描述 在实现锚点定位的时候发现无法设置滚动条的位置. 在Vue中,使用 document.body.scrollTop=952 无法设置滚动条的高度. document.body.scrollTo ...

  8. 基于vue练习demo:发表评论案例 (使用localStorage存储数据)

    前言 最近在学习 VUE的相关知识,之前学习html和css3和原生js及jq库时感觉还挺轻松,但是接触vue框架之后才发现需要了解的东西太多了(如 vue-router,vue-cli,webpac ...

  9. vue修改meta值_vue中动态设置meta标签和title标签的方法

    vue中动态设置meta标签和title标签的方法 因为和原生的交互是需要h5这边来提供meta标签的来是来判断要不要显示分享按钮,所有就需要手动设置meta标签,标题和内容 //router内的设置 ...

最新文章

  1. SAP CRM 产品主数据搜索时的权限检查实现 - Product search authorization check
  2. 白话数据结构之【最小生成树】(转载)
  3. 循环首次适应算法_遗传算法 | 了解底层, 摆脱工具箱
  4. Lucene为不同字段指定不同分词器(转)
  5. Julia: LaTeX 符号
  6. Android 阿里云热修复
  7. 全国青少年机器人技术等级考试标准 (三四级/arduino/mixly)
  8. 音频编解码G729 PCM
  9. Excel学习笔记一关于色彩
  10. Trajan求割边,强连通分量
  11. 深圳java程序员培训班哪里最好,深圳java程序员培训学费(学习Java要不要报班)
  12. html图片标签img的介绍以及基本用法详解
  13. Redis学习、缓存、持久化、哨兵模式
  14. python咋变汉语_Python3实现汉语转换为汉语拼音
  15. 【C++进阶知识】C++类的继承和派生
  16. 1、Android概述
  17. 如何用matlab中syms建立符号方程,用matlab求解符号方程及符号方程组
  18. echarts 画动态水球
  19. john the ripper 使用
  20. 基于Springboot体育馆预约管理系统

热门文章

  1. Flume 开发者指南V1.5.2
  2. python数据分析常用类库(1.1)
  3. js 数组头部添加_javaScript 为对象型数组创建表格
  4. ajax jsonp post php,※ajax的post方式注意点※及jsonp的封装
  5. java后端站内通知_正确使用Java事件通知
  6. c++ vscode 第三方库_请教下,vscode中怎么编译带第三方库的文件呢?谢谢! - C++程序设计语言 - CPlusPlus - 水木社区...
  7. python教程1003无标题_OSError:[WinError 10038]试图对非s的对象执行操作
  8. win10玩cf不能全屏_游戏莫名卡顿三招搞定!Win10游戏优化教程
  9. hfss仿真时间过长怎么解决_一文详解相控阵天线仿真技术
  10. 什么电脑的牌子好用_什么牌子的盘点机好用?