博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vuex组件 vuex-persistedstate
阅读量:7241 次
发布时间:2019-06-29

本文共 1674 字,大约阅读时间需要 5 分钟。

vuex用于管理项目中的全局状态,但是我们一刷新vuex中保存的全局状态就会被全部初始化,虽然我们也可以同事缓存到storage中做两步操作,但是vuex-persistedstate组件已经帮我们完成了同步更新

npm install vuex-persistedstate --save

然后用vuex中的plugins属性挂载

 
import createPersistedState from 'vuex-persistedstate'
export default new Vuex.Store({
  state,
  mutations,
  getters,
  plugins: [createPersistedState()]
})

在我们的localstorage中就会看到有一个vuex的key,值为{"showLogin":false,"navIndex":true,"token":"64c9bbf8541b47af8d891b20247ae6a3","nickName":"百宝箱","updataCart":false,"showLoading":false}的字符串的JSON数据

每次我们更新vuex的状态,localstorage中的vuex也会随之改变

API

createPersistedState([options])

使用给定的选项创建插件的新实例。可以提供以下选项来配置您的特定需求的插件:

  • key <String>:存储持久状态的键。(默认:vuex

  • paths <Array>:部分持续状态的任何路径的数组。如果没有路径给出,完整的状态是持久的。(默认:[]

  • reducer <Function>:一个函数,将被调用来减少基于给定的路径持久化的状态。默认包含这些值。

  • subscriber <Function>:一个被调用来设置突变订阅的函数。默认为store => handler => store.subscribe(handler)

  • storage <Object>:而不是(或与)getStatesetState。默认为localStorage。

  • getState <Function>:将被调用以重新水化先前持久状态的函数。默认使用storage

  • setState <Function>:将被调用来保持给定状态的函数。默认使用storage

  • filter <Function>:将被调用来过滤将setState最终触发存储的任何突变的函数。默认为() => true

自定义存储

如果在本地存储中存储Vuex存储的状态并不理想。人们可以轻松地实现功能使用(或任何其他你可以想到的);

import { Store } from 'vuex'import createPersistedState from 'vuex-persistedstate'import * as Cookies from 'js-cookie'const store = new Store({  // ...  plugins: [    createPersistedState({      storage: {        getItem: key => Cookies.get(key),        setItem: (key, value) => Cookies.set(key, value, { expires: 3, secure: true }),        removeItem: key => Cookies.remove(key)      }    })  ]})

实际上,可以传递任何遵循存储协议(getItem,setItem,removeItem等)的对象:

// 用sessionStorage替换localStorage createPersistedState({ storage: window.sessionStorage })

 

每一次的记录,都是向前迈进的一步

转载地址:http://utfbm.baihongyu.com/

你可能感兴趣的文章
Android开发周报:Flyme OS开源、经典开源项目解析
查看>>
uva 568(数学)
查看>>
【Hibernate】Hibernate系列4之配置文件详解
查看>>
centos7+redis+php环境配置
查看>>
割点、桥模板以及点双连通、边双连通
查看>>
Yii数据库操作增删改查-[增加\查询\更新\删除 AR模式]
查看>>
vs发布的程序不依赖运行时库msvcp100.dll
查看>>
jsp简单实现统计在线人数
查看>>
df、du、fdisk:Linux磁盘管理
查看>>
C#时间戳转换[转发]
查看>>
MySQL · 答疑解惑 · MySQL 锁问题最佳实践
查看>>
SDK的制作详解
查看>>
$.ajax()方法详解
查看>>
ssh登录很慢,登录上去后速度正常问题的解决方法
查看>>
socket实例1
查看>>
python 类
查看>>
css样式-表格优化
查看>>
大型网站系统架构演化之路
查看>>
多线程并发同一个表问题(li)
查看>>
【转载】Linux磁盘管理:LVM逻辑卷管理
查看>>