vuex页面刷新数据丢失问题的四种解决方式

作者:摸鱼小公举 时间:2024-04-09 10:58:50 

为什么说刷新页面vuex的数据会丢失

刷新页面vuex的数据会丢失属于正常现象,因为JS的数据都是保存在浏览器的堆栈内存里面的,刷新浏览器页面,以前堆栈申请的内存被释放,这就是浏览器的运行机制,那么堆栈里的数据自然就清空了。

第一种方法用sessionStorage

将接口返回的数据保存在vuex的store里,也将这些信息也保存在sessionStorage里。注意的是vuex中的变量是响应式的,而sessionStorage不是,当你改变vuex中的状态,组件会检测到改变,而sessionStorage就不会了,页面要重新刷新才可以看到改变,所以应让vuex中的状态从sessionStorage中得到,这样组件就可以响应式的变化。

在store文件夹里面的js文件 示例如下

const state = {
 authInfo: JSON.parse(sessionStorage.getItem("COMPANY_AUTH_INFO")) || {}
}

const getters = {
 authInfo: state => state.authInfo,
}
const mutations = {
 SET_COMPANY_AUTH_INFO(state, data) {
   state.authInfo = data
   sessionStorage.setItem("COMPANY_AUTH_INFO", JSON.stringify(data))
 }
}

//actions 模块里无需使用 sessionStorage

export default {
 namespaced: true,
 state,
 getters,
 mutations,
 //actions,
}

其实这里还可以用 localStorage,但是它没有期限;所以常用的还是sessionStorage,当浏览器关闭时会话结束。

第二种方法是 vuex-along

示例如下

(1)安装 vuex-along

npm install vuex-along --save

(2)在store文件夹里的index.js中引入vuex-along并配置相关代码

import Vue from 'vue'
import Vuex from 'vuex'
import indexOne from "./modules/indexOne"
import VueXAlong from 'vuex-along'

Vue.use(Vuex)
const store=new Vuex.Store({
   strict: false,
   modules:{
       indexOne
   },

plugins: [VueXAlong({
       name: 'along',     //存放在localStroage或者sessionStroage 中的名字
       local: false,      //是否存放在local中  false 不存放 如果存放按照下面session的配置配
       session: { list: [], isFilter: true }  
       //如果值不为false 那么可以传递对象 其中 当isFilter设置为true时, list 数组中的值就会被过滤调,这些值不会存放在seesion或者local中
     })]

})

export default store;

第三种方法是 vuex-persistedstate

示例如下

(1)安装 vuex-persistedstate

npm install --save vuex-persistedstate

(2)在store文件夹里的index.js中引入vuex-persistedstate并配置相关代码

import Vue from 'vue'
import Vuex from 'vuex'
import user from './modules/user'
import createPersistedState from "vuex-persistedstate"
Vue.use(Vuex)

const store = new Vuex.Store({
 modules: {
   user
 },

plugins: [createPersistedState({
   storage: window.sessionStorage,
   reducer(val) {
     return { // 只储存state中的user
       user: val.base
     }
   }
 })]
})

export default store;

第四种方法是 vuex-persist

示例如下

(1)安装 vuex-persist

npm install --save vuex-persist
or
yarn add vuex-persist

(2)在store文件夹里的index.js中引入vuex-persist并配置相关代码

import Vue from 'vue'
import Vuex from 'vuex'
import indexOne from "./modules/indexOne"
import VuexPersistence from 'vuex-persist'
Vue.use(Vuex)

const vuexLocal = new VuexPersistence({
   storage: window.localStorage
})

const store = new Vuex.Store({
   strict: false,
   modules:{
       indexOne,
   },
   plugins: [vuexLocal.plugin]

})

export default store;

结语:

其实解决此问题的方法有很多,基本上都是要借助于localStorage或者sessionStroage来存放。

来源:https://juejin.cn/post/7061858778756415519

标签:vuex,数据,丢失
0
投稿

猜你喜欢

  • Anaconda使用IDLE的实现示例

    2023-05-09 10:40:39
  • IE8新特性及IE8安装使用 目录

    2008-04-01 09:50:00
  • python矩阵的基本运算及各种操作

    2023-01-12 11:37:27
  • JavaScript观察者模式原理与用法实例详解

    2024-04-19 10:02:48
  • 基于Pydantic封装的通用模型在API请求验证中的应用详解

    2022-02-20 20:12:24
  • pygame实现贪吃蛇游戏

    2021-09-23 00:29:21
  • asp数字或者字符排序函数代码

    2011-02-24 11:00:00
  • Golang中字符串(string)与字节数组([]byte)一行代码互转实例

    2023-09-17 14:37:07
  • Python实现ATM系统

    2021-10-17 05:20:46
  • 利用Python如何制作好玩的GIF动图详解

    2023-03-02 10:47:47
  • MySql中如何使用 explain 查询 SQL 的执行计划

    2024-01-15 10:25:01
  • 网站508规范(译)

    2008-04-03 13:26:00
  • 教你快速掌握SQL语言中游标的使用技巧

    2009-01-08 16:24:00
  • 整理的比较全的一句话后门代码(方面大家查找后门)

    2023-06-17 18:30:29
  • 深入解析Python中的变量和赋值运算符

    2023-10-13 20:58:53
  • Python实战之利用Geopandas算出每个省面积

    2022-05-11 07:46:39
  • CSS.JS文件发布机制的思考

    2009-08-04 13:07:00
  • Django城市信息查询功能的实现步骤

    2023-09-01 21:28:48
  • 详解如何在ChatGPT内构建一个Python解释器

    2022-06-18 21:37:38
  • vue3封装轮播图组件的方法

    2024-06-07 16:03:16
  • asp之家 网络编程 m.aspxhome.com