当前位置: 首页 > article >正文

Vue3 Pinia持久化存储

文章目录

  • Vue3 Pinia持久化存储
    • 一、引言
    • 二、安装Pinia和持久化插件
      • 1、安装
      • 2、注册持久化插件
    • 三、定义Store并启用持久化
      • 1、组合式API定义Store
      • 2、选项式API定义Store
    • 四、使用Store
    • 五、高级持久化配置
      • 1、自定义存储的key值和存储方式
      • 2、选择性存储对应字段
    • 六、总结

Vue3 Pinia持久化存储

一、引言

在现代前端开发中,状态管理是构建交互式应用的核心部分。Vue3 引入了 Composition API,而 Pinia 成为了官方推荐的状态管理库。Pinia 不仅提供了简洁的 API,还支持持久化存储,这意味着我们可以将应用的状态保存在本地存储中,以便在页面刷新或重新加载后恢复状态。

二、安装Pinia和持久化插件

1、安装

可以通过 npm、yarn 或 pnpm 安装 Pinia 和持久化插件。

# 使用 npm
npm install pinia pinia-plugin-persist

# 使用 yarn
yarn add pinia pinia-plugin-persist

# 使用 pnpm
pnpm i pinia pinia-plugin-persist

2、注册持久化插件

在创建 Pinia 实例时,注册 pinia-plugin-persist 插件。

// src/stores/pinia.js
import { createPinia } from 'pinia'
import piniaPluginPersist from 'pinia-plugin-persist'

const pinia = createPinia()
pinia.use(piniaPluginPersist)

export default pinia

三、定义Store并启用持久化

1、组合式API定义Store

使用组合式 API 定义 Store,并设置 persist 选项来启用持久化。

// src/stores/user.js
import { defineStore } from 'pinia'

export const useUserStore = defineStore('user', {
  state: () => ({
    username: '',
    token: ''
  }),
  actions: {
    login(username, token) {
      this.username = username
      this.token = token
    },
    logout() {
      this.username = ''
      this.token = ''
    }
  },
  persist: {
    enabled: true,
    strategies: [
      {
        key: 'user',
        storage: localStorage
      }
    ]
  }
})

2、选项式API定义Store

使用选项式 API 定义 Store,并同样设置 persist 选项。

// src/stores/cart.js
import { defineStore } from 'pinia'

export const useCartStore = defineStore('cart', {
  persist: true,
  state: () => ({
    items: []
  }),
  getters: {
    itemCount: (state) => state.items.length
  },
  actions: {
    addItem(item) {
      this.items.push(item)
    },
    clearCart() {
      this.items = []
    }
  }
})

四、使用Store

在组件中使用定义好的 Store。

<template>
  <div>
    <div>Username: {{ userStore.username }}</div>
    <button @click="userStore.login('kimi', '123456')">Login</button>
    <button @click="userStore.logout">Logout</button>
    <div>Cart Item Count: {{ cartStore.itemCount }}</div>
    <button @click="cartStore.addItem({ id: 1, name: 'Apple' })">Add Apple</button>
    <button @click="cartStore.clearCart">Clear Cart</button>
  </div>
</template>

<script setup>
import { useUserStore } from '@/stores/user'
import { useCartStore } from '@/stores/cart'

const userStore = useUserStore()
const cartStore = useCartStore()
</script>

五、高级持久化配置

1、自定义存储的key值和存储方式

persist: {
  enabled: true,
  strategies: [
    {
      key: 'custom_user',
      storage: sessionStorage // 使用 sessionStorage 而不是 localStorage
    }
  ]
}

2、选择性存储对应字段

persist: {
  enabled: true,
  strategies: [
    {
      storage: localStorage,
      paths: ['username'] // 只持久化 username 字段
    }
  ]
}

六、总结

通过使用 Pinia 和 pinia-plugin-persist 插件,我们可以轻松实现状态的持久化存储。无论是使用组合式 API 还是选项式 API,Pinia 都提供了灵活的方式来定义和持久化状态。这不仅增强了用户体验,还使得状态管理更加强大和灵活。


版权声明:本博客内容为原创,转载请保留原文链接及作者信息。

参考文章

  • Vue3 pinia持久化存储(组合式Api案例演示)
  • Vue3如何使用Pinia详细介绍、pinia持久化存储(pinia-plugin-persistedstate详细配置)

http://www.kler.cn/a/330075.html

相关文章:

  • 【大模型系列篇】数字人音唇同步模型——腾讯开源MuseTalk
  • [Linux]Docker快速上手操作教程
  • 【Rust】错误处理机制
  • opencv的NLM去噪算法
  • rk3568 , buildroot , qt ,使用sqlite, 动态库, 静态库
  • 【STM32+QT项目】基于STM32与QT的智慧粮仓环境监测与管理系统设计(完整工程资料源码)
  • 基于Hive和Hadoop的保险分析系统
  • 【数据结构】线性表
  • CSS3过渡
  • CSP-J 复赛算法 贪心算法练习
  • Elasticsearch学习笔记(2)
  • [RabbitMQ] 7种工作模式详细介绍
  • 腾讯云SDK基本概念
  • OpenGL ES 之EGL(6)
  • 学生课堂行为检测数据集 8800张 上课行为 标注voc yolo 7类
  • [Go语言快速上手]函数和包
  • 在Kali Linux中使用VNC和iptables配置xrdp以实现远程连接
  • 一文上手SpringSecurity【七】
  • OpenGL笔记之事件驱动设计将相机控制类和应用程序类分离
  • 三、数据链路层(上)
  • Spring Boot与GraphQL:现代化API设计
  • 《Ubuntu20.04环境下的ROS进阶学习7》
  • Windows 10再次成为Steam上最受欢迎的操作系统 Linux用户比例略有下降
  • Redis:初识Redis
  • 【git】提交更改到仓库
  • 让CSS flex布局最后一行列表左对齐的N种方法