vuex-persistedstate插件的原理是什么,怎么实现存储
Admin 2022-09-05 群英技术资讯 1358 次浏览
今天这篇给大家分享的知识是“vuex-persistedstate插件的原理是什么,怎么实现存储”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享发大家做个参考,希望这篇“vuex-persistedstate插件的原理是什么,怎么实现存储”文章能帮助大家解决问题。最近在做Vue项目中的登录模块,登陆成功后获取到token,将token存储在vuex中,然而我发现切换路由后vuex中的数据都恢复默认了,原来页面刷新之后vuex的数据都会恢复默认。而后面进行鉴权处理需要token,于是我们要将vuex中的数据进行本地存储。
这里就用到了vuex持久化插件vuex-persistedstate
这个插件的原理结合了存储方式,只是统一配置后就不需要手动写存储方法了
使用方法:
安装
npm install vuex-persistedstate --save
在store下的index.js中引入配置
import { createStore } from 'vuex'
import createPersistedState from 'vuex-persistedstate'
export default createStore({
state: { },
mutations: { },
actions: { },
modules: { },
plugins: [
createPersistedState(),
],
})
这样是默认存储到localStorage,如果想要存储到sessionStorage,配置如下
import { createStore } from 'vuex'
import createPersistedState from 'vuex-persistedstate'
export default createStore({
state: { },
mutations: { },
actions: { },
modules: { },
plugins: [
// 把vuex的数据存储到sessionStorage
createPersistedState({
storage: window.sessionStorage,
}),
],
})
默认持久化所有的state,如果想要存储指定的state,配置如下
import { createStore } from 'vuex'
import createPersistedState from 'vuex-persistedstate'
export default createStore({
state: { },
mutations: { },
actions: { },
modules: { },
plugins: [
// 把vuex的数据存储到sessionStorage
createPersistedState({
storage: window.sessionStorage,
reducer(val) {
return {
// 只存储state中的userData
userData: val.userData
}
}
}),
],
})
key:存储持久状态的key(默认vuex)paths:部分持续状态的任何路径的数组。如果没有路径给出,完整的状态是持久的。(默认:[])reducer:一个函数,将被调用来基于给定的路径持久化的状态。默认包含这些值。subscriber:一个被调用来设置突变订阅的函数。默认为store => handler => store.subscribe(handler)storage:而不是(或与)getState和setState。默认为localStorage。getState:将被调用以重新水化先前持久状态的函数。默认使用storage。setState:将被调用来保持给定状态的函数。默认使用storage。filter:将被调用来过滤将setState最终触发存储的任何突变的函数。默认为() => trueVuex是一个专为 Vue.js 应用程序开发的状态管理模式
vuex就是一个仓库 众所周知就是存放公共数据的一个地方 任何组件内的都可以使用vuex中的数据
State存放Vuex store实例的状态对象,用于定义共享的数据, 以及设定的变量
Action向store发出调用通知,去执行异步操作
Mutations它只用于修改state中定义的状态变量 , 相当于vue当中methods 来进行逻辑的代码操作
Modules对state进行分类处理,相当于模块
getters外部程序通过它获取变量的具体值,或者在取值前做一些计算(可以认为是store的计算属性)
plugins这个是数组展示 而不是以对象形式展示 ,数组当中是对象的形式 数组当中存放vuex的本地存储
vuex-persist是vuex是一个插件 数据的缓存, 跟localStorage是一个本质的意思,将数据存储在用户的本地,当然这个插件的特性只能在vuex当中使用,在vue中就使用不了
那么 vuex-persist 如何使用
在终端当中下载
cnpm install vuex-persist -save
下载完成后 还需要在vuex当中引入
import vuexPersist from 'vuex-persist';
引入之后需要在 export default 当中 实例化出
plugins:[
new vuexPersist({
localstorage:window.localStorage,
}).plugin,
],
new 一个对象出 对象中写入 localStorage
new 出的对象需要跟引入的 名字相同
以上方式相对来说复杂
在终端当中直接下载
cnpm install vuex-persistedstate -save
在plugins 中直接调用即可 这种方法先对简单 不需要再去new一下
plugins: [
Persist()
]
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章给大家分享的是JS中getday方法的相关内容。在javascript中,escape()方法能用于指定日期是星期几,小编觉得挺实用的,因此分享给大家做个参考,文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起学习一下吧。
这篇文章主要为大家详细介绍了JS实现网页导航条特效,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
在 Vue.js 中,v-for 循环是非常使用的,它允许您在模板代码中编写 for 循环。因此,这篇文章就给大家分享一下v-for循环使用技巧,有需要的朋友可以参考。
本篇文章给大家分享5个使用 promise 时的常见错误,帮大家快速避坑,希望对大家有所帮助!
私有变量的概念是,在任何函数中定义的变量,都是私有变量,因为不能在函数外部访问这些变量。与其他Java,C++语言等不同,在JavaScript中是没有私有属性的不能用关键字来声明的私有变量。在JavaScript是没有私有属性的概念的,所有属性都是公用的。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008