Vuex持久化插件(vuex-persistedstate)-解决刷新数据消失的问题-程序员宅基地

技术标签: ViewUI  javascript  

vuex可以进行全局的状态管理,但刷新后刷新后数据会消失,这是我们不愿意看到的。怎么解决呢,我们可以结合本地存储做到数据持久化,也可以通过插件-vuex-persistedstate。

1.手动利用HTML5的本地存储
方法
  • vuex的state在localStorage或sessionStorage或其它存储方式中取值
  • 在mutations,定义的方法里对vuex的状态操作的同时对存储也做对应的操作。 这样state就会和存储一起存在并且与vuex同步
问题
  • 最直观的就是,手动写比较麻烦。
2.利用vuex-persistedstate插件

插件的原理其实也是结合了存储方式,只是统一的配置就不需要手动每次都写存储方法

使用方法
安装
npm install vuex-persistedstate --save
复制代码
引入及配置

在store下的index.js中

import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
  // ...
  plugins: [createPersistedState()]
})
复制代码

默认存储到localStorage

想要存储到sessionStorage,配置如下
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
  // ...
  plugins: [createPersistedState({
      storage: window.sessionStorage
  })]
})
复制代码
想使用cookie同理

默认持久化所有state

指定需要持久化的state,配置如下
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
  // ...
  plugins: [createPersistedState({
      storage: window.sessionStorage,
      reducer(val) {
          return {
          // 只储存state中的assessmentData
          assessmentData: val.assessmentData
        }
     }
  })]
复制代码
vuex引用多个插件的写法

譬如:vuex提示的插件和持久化的插件一起使用,配置如下

import createPersistedState from "vuex-persistedstate"
import createLogger from 'vuex/dist/logger'
// 判断环境 vuex提示生产环境中不使用
const debug = process.env.NODE_ENV !== 'production'
const createPersisted = createPersistedState({
  storage: window.sessionStorage
})
export default new Vuex.Store({
 // ...
  plugins: debug ? [createLogger(), createPersisted] : [createPersisted]
})
复制代码

plugins要是一个一维数组不然会解析错误

转载于:https://juejin.im/post/5cd274bc5188254088472d09

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_34187862/article/details/91419307

智能推荐

创新者的窘境 Teh Innovator‘s Dilemma_sustaining 创新-程序员宅基地

文章浏览阅读389次。成功的企业家需要投资错误。创新有两种类型:1、持续型创新 Sustaining Innovations:在现有产品或服务上的精进,对存量客户或商业模型的价值增益。到最后,你提供的服务会比客户实际需要的更多,过量服务=创新。2、破坏性创新 Disruptive Innovations: 这类创新提供的产品比市场现有产品的性能差,也许是低质量或者低精密度的,但是他们却更简单、更便宜、体验更友好。破坏性创新会击败强大的现存企业,并不是因为这些企业有弱点,而是因为这些企业为了建立客户黏性而选择在现有_sustaining 创新

C++使用nlohmann/json 转 C++ 结构体_josn.hpp向量转为c++结构体-程序员宅基地

文章浏览阅读1.5k次。参考网址:https://icode.best/i/33144046003522使用宏展开的方式:其中的宏定义在json.hpp中:nlohmann_json_j.value(#v1, nlohmann_json_t.v1);这里使用json.value的取值方式。_josn.hpp向量转为c++结构体

ASP.NET简介_asp.net是什么-程序员宅基地

文章浏览阅读2.5k次。前言ASP.NET对于我这个菜鸟来说还是比较陌生的,不太清楚时怎么回事,当然网上有好多介绍ASP.NET 的,我的这篇博客就是通过各种查资料总结出来的.算时一个拼凑的介绍版本吧!正文ASP.NET简介微软官网上的原话是这么说的:ASP.NET is an open source web framework for building modern web apps and services..._asp.net是什么

TypeC拓展设计方案|TypeC转HDMI设计方案|CS5261/CS5265芯片设计参数对比_typec转hdmi芯片-程序员宅基地

文章浏览阅读473次。集睿智远CS5261/CS5265都可以用于设计TypeC转HDMI方案,低成本TypeC扩展坞设计方案,而两者也有些差异:1.CS5261支持DP1.4输入,一个HDMI1.4输出,即HDMI输出为4K30HZ;CS5466ANC to HDMI8K30(4K144) by 2Lane(集成PD3.0、可挂3.0HUB)支持RG 4:4:4 8/10位pc和YCCr 4:4:4、4:2:2、4:2:0 8/10位pc。HDMI规范v2.0转换,数据速率高达每通道6-Gps。Type-C规范1.2。_typec转hdmi芯片

Android进阶之路 - 简单实现聊天功能_android客服聊天功能模板-程序员宅基地

文章浏览阅读2.3k次,点赞6次,收藏31次。记得几年以前看到聊天功能时总是不得所以,现在回头一看,发现其实实现方式非常简单,故此记录一番 ~ 实现效果实现思想实现方式导入依赖创建model创建适配器使用场景实现效果一个入门级的Demo、只能满足基本需求 ~实现思想一个垂直的list列表一个有tag的model标记tag,用于区分用户不同tag,展示不同UI实现方式导入依赖篇中用到的 RecyclerVie..._android客服聊天功能模板

随便推点

Linux打包python(pyinstaller)及问题解决_linux pyinstaller-程序员宅基地

文章浏览阅读994次,点赞22次,收藏20次。弄了两周,一堆办法都没有用,我混合了好几个办法弄好了。_linux pyinstaller

AOSP ~ 默认属性值_def_usb_mass_storage_enabled-程序员宅基地

文章浏览阅读863次。AOSP ~ 默认属性值_def_usb_mass_storage_enabled

C语言——从键盘输人三角形的三个边长 a、b、c,求出三角形的面积。_编写程序,输入三角形三条边的边长a、b和c,输出三角形的面积-程序员宅基地

文章浏览阅读1.8k次,点赞7次,收藏14次。从键盘输人三角形的三个边长 a、b、c,求出三角形的面积。求三角形的面积用公式area=sqrt(s*(s-a)*(s-b)*(s-c)),其中 s=1/2(a十b+c)。注:要求对输人三角形的三个边长做出有效性判断。_编写程序,输入三角形三条边的边长a、b和c,输出三角形的面积

论文 Convolutional Networks for Images, Speech, and Time-Series-程序员宅基地

文章浏览阅读675次。论文 Convolution Networks for Images, Speech, and Time-Series1 IntroductionThe ability of multilayer back-propagation networks to learn complex, heigh-dimensional,non-linear mapping from large collection of examples make them obvious candidates for image r

[附源码]Nodejs计算机毕业设计基于的图书馆管理系统Express(程序+LW)_基于node.js的图书管理系统需求分析与 系统设计-程序员宅基地

文章浏览阅读152次。该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程。欢迎交流项目运行环境配置:。项目技术:Express框架 + Node.js+ Vue 等等组成,B/S模式 +Vscode管理+前后端分离等等。环境需要1.运行环境:最好是Nodejs最新版,我们在这个版本上开发的。其他版本理论上也可以。2.开发环境:Vscode或HbuilderX都可以。推荐HbuilderX;3.mysql环境:建议是用5.7版本均可4.硬件环境:windows 7/8/10 1G内存以上。_基于node.js的图书管理系统需求分析与 系统设计

推荐文章

热门文章

相关标签