解决vuex刷新数据消失问题


Posted in Javascript onNovember 12, 2020

前言

vue构建的单页大型项目中,可能会用到Vuex 。Vuex 的状态存储是响应式的,当 Vue 组件从 store 中读取状态的时候,若 store 中的状态发生变化,那么相应的组件也会相应地得到高效更新。

但是有一个问题就是:vuex的存储的数据只是在页面的中,相当于我们定义的全局变量,刷新之后,里边的数据就会恢复到初始化状态。但是这个情况有时候并不是我们所希望的。

比如,用户已经登录了,我把登录状态放到state中了,一刷新页面,还要重新登录?购物车里的添加的数据,一刷新要重新添加?

解决思路:

监听页面是否刷新,如果页面刷新了,将state对象存入到sessionStorage/localStorage中。

页面打开之后,判断sessionStorage/localStorage中是否存在state对象,如果存在,则说明页面是被刷新过的,将sessionStorage/localStorage中存的数据取出来给vuex中的state赋值。

如果不存在,说明是第一次打开,则取vuex中定义的state初始值。

sessionStorage和localStorage介绍

H5提供了我们常用的localStorage和sessionStorage。

两者的区别:localStorage生命周期是永久,这意味着除非用户显示在浏览器提供的UI上清除localStorage信息,否则这些信息将永远存在。

存放数据大小为一般为5MB,而且它仅在客户端(即浏览器)中保存,不参与和服务器的通信。sessionStorage仅在当前会话下有效,关闭页面或浏览器后被清除。

存放数据大小为一般为5MB,而且它仅在客户端(即浏览器)中保存,不参与和服务器的通信。

源生接口可以接受,亦可再次封装来对Object和Array有更好的支持。浏览器的支持除了IE7及以下不支持外,其他标准浏览器都完全支持(ie及FF需在web服务器里运行)

解决vuex刷新数据消失问题

localStorage和sessionStorage都具有相同的操作方法,例如setItem、getItem、removeItem、clear等。

代码:

项目目录结构:

解决vuex刷新数据消失问题

在项目的入口页面(App.vue)里添加监听刷新事件:

name: 'App',
 mounted () {
 window.addEventListener('unload', this.saveState)
 },
 methods: {
 saveState () {
  sessionStorage.setItem('state', JSON.stringify(this.$store.state))
 }
 }

store里有可能存储了一些涉密的信息,所以一直在 sessionStorage放着不是太好,页面加载完成后,清空或者删除指定的session。

window.addEventListener("load", () => {
  sessionStorage.clear();
 });

state.js:

var state = sessionStorage.getItem('state') ? JSON.parse(sessionStorage.getItem('state')) : {
 count: 1,
 obj: {},
 arr: [1, 2, 3]
}
export default state

index.js

import Vue from 'vue'
import Vuex from 'vuex'
import state from './states'
import mutations from './mutations'
import getters from './getters'
import actions from './actions'
Vue.use(Vuex)
export default new Vuex.Store({
 state,
 mutations,
 getters,
 actions
})

mutations.js:

import {
 SOME_MUTATION
} from './mutation-types.js'
 
export default {
 [SOME_MUTATION] (state) {
 state.count++
 }
}

mutation-types.js

export const SOME_MUTATION = 'SOME_MUTATION'

补充知识:vuex-along有效防止刷新页面后vuex中的数据重置

1.vuex-along安装

npm i vuex-along --save

2.在store目录下的index.js文件中引入

2.1

import {createVuexAlong} from 'vuex-along'

2.2直接上图

解决vuex刷新数据消失问题

简单说明其中的含义:

name:“”“”

//在这块我存入的是localstorage,代表localstorage的键值

local:{list:["userInfo"],isFilter:true}

//list:要过滤的vuex中的数据,isFilter代表将userInfo滤过,其余存进localstorage

session:false

//对于sessionstorage不进行任何操作

更加详细信息借助github进行了解:https://github.com/boenfu/vuex-along

3.以上这篇解决vuex刷新数据消失问题就是小编分享给大家的全部内容了,希望对各位将来的大佬有所帮助!也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
详谈jQuery中的this和$(this)
Nov 13 Javascript
jquery制作多功能轮播图插件
Apr 02 Javascript
javascript中return,return true,return false三者的用法及区别
Nov 17 Javascript
jQuery Mobile 和 Kendo UI 的比较
May 05 Javascript
微信小程序 window_x64环境搭建
Sep 30 Javascript
React中ES5与ES6写法的区别总结
Apr 21 Javascript
微信小程序“摇一摇”的实例代码
Jul 20 Javascript
vue-lazyload使用总结(推荐)
Nov 01 Javascript
JS中call()和apply()的功能及用法实例分析
Jun 28 Javascript
基于node+websocket+html实现腾讯课堂聊天室聊天功能
Mar 04 Javascript
antd中table展开行默认展示,且不需要前边的加号操作
Nov 02 Javascript
jenkins自动构建发布vue项目的方法步骤
Jan 04 Vue.js
微信小程序对图片进行canvas压缩的方法示例详解
Nov 12 #Javascript
解决vuex改变了state的值,但是页面没有更新的问题
Nov 12 #Javascript
javascript实现搜索筛选功能实例代码
Nov 12 #Javascript
vue实现两个组件之间数据共享和修改操作
Nov 12 #Javascript
vue 解决mintui弹窗弹起来,底部页面滚动bug问题
Nov 12 #Javascript
vue打包通过image-webpack-loader插件对图片压缩优化操作
Nov 12 #Javascript
详解ES6 扩展运算符的使用与注意事项
Nov 12 #Javascript
You might like
php下过滤html代码的函数 提高程序安全性
2010/03/02 PHP
基于curl数据采集之正则处理函数get_matches的使用
2013/04/28 PHP
PHP实现视频文件上传完整实例
2014/08/28 PHP
9个经典的PHP代码片段分享
2014/12/18 PHP
PHPstorm启用自动换行的方法详解(IDE)
2020/09/17 PHP
php的lavarel框架中join和orWhere的用法
2020/12/28 PHP
javascript中注册和移除事件的4种方式
2013/03/20 Javascript
jQuery 关于伪类选择符的使用说明
2013/04/24 Javascript
jQuery实现鼠标经过图片变亮其他变暗效果
2015/05/08 Javascript
JavaScript中push(),join() 函数 实例详解
2016/09/06 Javascript
layui 优化button按钮和弹出框的方法
2018/08/15 Javascript
微信小程序新手教程之启动页的重要性
2019/03/03 Javascript
layui富文本编辑器前端无法取值的解决方法
2019/09/18 Javascript
vue中改变滚动条样式的方法
2020/03/03 Javascript
Python实现的二维码生成小软件
2014/07/11 Python
python计算对角线有理函数插值的方法
2015/05/07 Python
python如何通过实例方法名字调用方法
2018/03/21 Python
简单实现python数独游戏
2018/03/30 Python
win7+Python3.5下scrapy的安装方法
2018/07/31 Python
Python爬取成语接龙类网站
2018/10/19 Python
对python 操作solr索引数据的实例详解
2018/12/07 Python
django如何自己创建一个中间件
2019/07/24 Python
python 字符串常用函数详解
2019/09/11 Python
Python ArgumentParse的subparser用法说明
2020/04/20 Python
python编写一个会算账的脚本的示例代码
2020/06/02 Python
基于CSS3制作立体效果导航菜单
2016/01/12 HTML / CSS
Html5页面内使用JSON动画的实现
2019/01/29 HTML / CSS
Canvas获取视频第一帧缩略图的实现
2020/11/11 HTML / CSS
DHC美国官网:日本通信销售第一的化妆品品牌
2017/11/12 全球购物
护理专业大学生自我推荐信
2014/01/25 职场文书
教师学习八项规定六项禁令思想汇报
2014/09/27 职场文书
学生实习证明范文
2014/09/28 职场文书
2015年税务稽查工作总结
2015/05/26 职场文书
小学英语教师研修感悟
2015/11/18 职场文书
Mysql 如何查询时间段交集
2021/06/08 MySQL
详解Go语言运用广度优先搜索走迷宫
2021/06/23 Python