pinia从定义到运用

Pinia 是 Vue 官方推荐的新一代状态管理库 ,专为 Vue3 设计,用来替代 Vuex。它以"轻量、直观、TypeScript 友好"著称,核心只有 state(数据)getters(计算值)actions(方法) 三个概念。

一、Pinia 是什么

  1. 定义:一个"全局数据仓库",跨组件/页面共享状态,与组件树解耦

  2. 与 Vuex 对比

  • 去掉 Mutation,同步异步都写在 actions 里。
  • 无需嵌套模块,每个 store 天然独立
  • 体积 ≈ 1 kB;支持 Vue2 / 3 和 SSR。
  • 配合 TypeScript 类型推导极佳

二、安装与启动

js 复制代码
# npm
npm i pinia
# main.ts
import { createPinia } from 'pinia'
app.use(createPinia())

三、创建 Store(两种语法)

  1. Option 风格(类 Vuex)
ts 复制代码
// src/stores/counter.ts
import { defineStore } from 'pinia'

export const useCounterStore = defineStore('counter', {
  state: () => ({ count: 0 }),
  getters: {
    double: (state) => state.count * 2
  },
  actions: {
    increment() { this.count++ },
    async asyncAdd(n: number) {
      await delay(500)
      this.count += n
    }
  }
})
  1. Setup 风格(Composition API)
ts 复制代码
export const useCounterStore = defineStore('counter', () => {
  const count = ref(0)
  const double = computed(() => count.value * 2)
  function increment() { count.value++ }
  return { count, double, increment }
})

四、在组件里使用

vue 复制代码
<script setup>
import { useCounterStore } from '@/stores/counter'
import { storeToRefs } from 'pinia'

const store = useCounterStore()
// 保持响应式解构
const { count, double } = storeToRefs(store)
// 方法直接解构即可
const { increment, asyncAdd } = store
</script>

<template>
  <p>{{ count }} / {{ double }}</p>
  <button @click="increment">+1</button>
  <button @click="asyncAdd(5)">async +5</button>
</template>

五、操作 state 的常见姿势

需求 写法示例(在组件内)
直接改 store.count = 10
批量改 store.$patch({ count: 10, msg:'ok' }) 或传入函数
整体替换 store.$state = { count: 0, ... }
重置为初始值 store.$reset()

六、数据持久化(刷新不丢)

css 复制代码
npm i pinia-plugin-persistedstate
TS 复制代码
// main.ts
import piniaPluginPersistedstate from 'pinia-plugin-persistedstate'
pinia.use(piniaPluginPersistedstate)

// store 里打开开关
export const useCounterStore = defineStore('counter', {
  state: () => ({ count: 0 }),
  persist: true          // 默认存在 localStorage
})

七、调试与 DevTools

  • 安装 Vue DevTools 6+ 即可看到所有 store 的实时值、调用栈。
  • 生产环境默认关闭,可手动开启 pinia.use(devtools)

八、小结(记住 3 句话)

  1. "全局变量"放 state,需要缓存的计算值放 getters,改数据全写 actions。
  2. 组件里 storeToRefs 保住响应式,方法直接解构。
  3. 想持久化就装 pinia-plugin-persistedstate,一行 persist: true 搞定。
相关推荐
妙码生花8 分钟前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
Awu12271 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude
咪库咪库咪1 小时前
Vue3-生命周期
前端
莪_幻尘2 小时前
你的 AI Skill 越多越蠢?Token 上下文爆炸的求生指南
前端·ai编程
lichenyang4532 小时前
从 has.echo 到异步 API 注册表:一次 ASCF API 回调不触发的排查复盘
前端
林瞅瞅2 小时前
Nuxt3 项目部署 Nginx 防盗链后特定 JS 文件 403 问题修复方案
前端
kyriewen3 小时前
别再每次都 Google 了:我整理了前端日常最常踩的 10 个 Git 坑,附速查表
前端·javascript·git
一颗奇趣蛋3 小时前
Web 视频开发完全指南:从入门到精通
前端
非洲农业不发达3 小时前
windows终端体验大升级,让你拥有macos级别的美化
前端·后端
妙码生花3 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十七):登录接口完善,登录页接口整合,解决跨域
前端·后端·ai编程