web vue之状态管理Pinia

一、Pinia 是什么?

Pinia 是 Vue 官方推荐的全新状态管理库(可看作 Vuex 的替代品),用于在多个组件间共享数据。

优点包括:

更简单的语法(无 mutations)

支持 TypeScript

响应式更强,性能更好

DevTools 支持出色

二、安装 Pinia

在一个 Vue 3 项目(例如用 Vite 创建的)中运行:

npm install pinia

如果你还没创建项目,可以先这样:

bash 复制代码
npm create vite@latest my-vue-app -- --template vue
cd my-vue-app
npm install
npm install pinia

三、在 main.js 中注册 Pinia

📄 src/main.js

typscript 复制代码
import { createApp } from 'vue'
import { createPinia } from 'pinia'
import App from './App.vue'

const app = createApp(App)
const pinia = createPinia()

app.use(pinia)
app.mount('#app')

四、创建一个 Store

📄 src/stores/counter.js

typescript 复制代码
import { defineStore } from 'pinia'

// 定义一个 counter store
export const useCounterStore = defineStore('counter', {
  state: () => ({
    count: 0,
    name: 'Victor'
  }),
  getters: {
    doubleCount: (state) => state.count * 2
  },
  actions: {
    increment() {
      this.count++
    },
    reset() {
      this.count = 0
    }
  }
})

五、在组件中使用 Store

📄 src/App.vue

typescript 复制代码
<template>
  <div style="padding: 20px">
    <h2>Pinia Demo</h2>
    <p>Count: {{ counter.count }}</p>
    <p>Double: {{ counter.doubleCount }}</p>

    <button @click="counter.increment">➕ 加 1</button>
    <button @click="counter.reset">🔄 重置</button>

    <hr />
    <p>用户名: {{ counter.name }}</p>
    <input v-model="counter.name" placeholder="修改用户名" />
  </div>
</template>

<script setup>
import { useCounterStore } from './stores/counter'

const counter = useCounterStore()
</script>

<style>
button {
  margin-right: 8px;
  padding: 6px 12px;
}
</style>

六、运行项目

bash 复制代码
npm run dev

打开浏览器访问控制台提示的地址(默认是 http://localhost:5173/)即可看到效果

🎉

七、Pinia 一般使用场景

场景 示例

✅ 全局状态共享 比如保存登录用户信息、token、主题颜色等

✅ 多组件共享数据 父子组件或兄弟组件共享同一个状态

✅ 请求缓存 请求数据后缓存到 store,下次直接使用

✅ 复杂业务逻辑 将逻辑封装在 actions 里统一管理(类似 Vuex 的 actions)

✅ 组合多个 store 模块 可按业务功能拆分成多个 store 文件

八、扩展:组合多个 store 示例

// src/stores/user.js

typescript 复制代码
export const useUserStore = defineStore('user', {
  state: () => ({ name: 'Guest', token: '' }),
  actions: {
    login(name) {
      this.name = name
      this.token = 'mock-token'
    }
  }
})
```

在组件中使用:
```typescript
<script setup>
import { useUserStore } from './stores/user'
const user = useUserStore()
user.login('Victor')
</script>
```
相关推荐
2501_920931705 小时前
React Native鸿蒙跨平台采用ScrollView的horizontal属性实现横向滚动实现特色游戏轮播和分类导航
javascript·react native·react.js·游戏·ecmascript·harmonyos
0思必得07 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东5167 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino7 小时前
图片、文件的预览
前端·javascript
2501_920931709 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
layman05289 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔9 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李9 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN9 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒9 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局