Pinia内存常驻

之前一期中讲过Pinia【在Vue 3中使用Pinia:简洁高效的状态管理】,新的状态管理更加高效,今天来讲一讲如何让 Pinia 数据常驻。

1、下载包 pinia-plugin-persistedstate

// npm
npm install pinia-plugin-persistedstate
// yarn
yarn add pinia-plugin-persistedstate

2、创建文件 /store/index.js

这里把插件pinia-plugin-persistedstate, use到 pinia 内部后, 就可以在建立 store 时使用内存常驻了

/**pinia */
import { createPinia } from 'pinia';
/**内存常驻 */
import piniaPluginPersistedState from 'pinia-plugin-persistedstate'
/**创建 */
const pinia = createPinia();
/**use */
pinia.use(piniaPluginPersistedState)

export default pinia

3、在 store 中使用

这里使用了 persist: true ,代表将此 store 中的所有 数据全部常驻在浏览器中

import { defineStore } from 'pinia'

const useLoginStore = defineStore("login", {
    persist: true, // 持久保存
    state: (): InitStateType => ({
        isLogin: false,
        isShow: false,
        token: "",
        userInfo: {}
    }),
    actions: {
        // 设置token
        setToken (token: string) {
            this.token = token
        },
    }
})

export default useLoginStore;

下面介绍将 单个 数据常驻在浏览器中

import { defineStore } from 'pinia'

const useLoginStore = defineStore("login", {
    persist: {
        paths: ["token"] // 只将 token 常驻在浏览器中
    },
    state: (): InitStateType => ({
        isLogin: false,
        isShow: false,
        token: "",
        userInfo: {}
    }),
    actions: {
        // 设置token
        setToken (token: string) {
            this.token = token
        },
    }
})

export default useLoginStore;

这种内存常驻的好出就是拿取数据规范,不用在 cookie 或者 localstorage 中储存与取用。

  • 8
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值