Pinia基础

Pinia是Vue的轻量级状态管理库,替代Vuex的新选择。它支持Vue2和Vue3,具有独立的store、TypeScript支持、小体积以及插件系统,如持久化存储。Pinia的使用包括创建store、定义state、getter、action,以及通过actions处理业务逻辑。此外,Pinia还允许模块化和通过插件实现状态持久化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Pinia

  • 概念:一个跨组件/页面共享状态的Vue存储库(Vuex5版本)

  • 优点:

    • Vue2 和 Vue3 都支持
    • Pinia 中只有 state、getter、action
    • 良好的 TypeScript 支持
    • Pinia 中每个 store 都是独立的,互相不影响
    • 体积非常小,只有 1kb 左右
    • Pinia支持插件来扩展自身功能
    • 支持服务端渲染

1、安装:yarn add pinia

2、将pinia挂载到Vue应用中(全局jS/ts中)

import { createApp } from "vue";
import App from "./App.vue";
import { createPinia } from "pinia";
const pinia = createPinia();

const app = createApp(App);
app.use(pinia);
app.mount("#app");

3、创建store

ps:使用 pinia 提供的 defineStore() 方法来创建一个 store ,该 store 用来存放我们需要全局使用的数据。

import { defineStore } from 'pinia'

// 第一个参数是应用程序中 store 的唯一 id
export const useUsersStore = defineStore('store的名字', {
   // 其它配置项
})

4、使用store

ps:直接引入我们声明的useUsersStore 方法即可

<script setup lang="ts">
import { useUsersStore } from "../src/store/user";
const store = useUsersStore();
console.log(store);
</script>

5、添加state

defineStore 函数创建了一个store,该函数第二个参数是一个options配置项,我们需要存放的数据就放在options对象中的state属性内。

state接收的是一个箭头函数返回的值,它不能直接接收一个对象

export const useUsersStore = defineStore("users", {
  state: () => {
    return {
      name: "小猪课堂",
      age: 25,
      sex: "男",
    };
  },
})

6、操作 state

6.1、读取state(其他组件使用写法一样)
import { useUsersStore } from "../src/store/user";
// 使用pinia的storeToRefs函数,将state中的数据变为响应式
import { storeToRefs } from 'pinia'; 
const store = useUsersStore();
// 读取state
const { name, age, sex } = storeToRefs(store);
6.2、修改state的数据

ps:使用pinia的 storeToRefs 函数,将state中的数据变为响应式

<template>
  <p>姓名:{{ name }}</p>
  <p>年龄:{{ age }}</p>
  <p>性别:{{ sex }}</p>
  <button @click="changeName">更改姓名</button>
</template>
<script setup lang="ts">
import { useUsersStore } from "../src/store/user";
import { storeToRefs } from 'pinia'; 
const store = useUsersStore();
const { name, age, sex } = storeToRefs(store);
// 更改姓名
const changeName = () => {
  store.name = "张三";
  console.log(store);
};
</script>
6.3、重置state

ps:调用store的 $reset() 方法

<button @click="reset">重置store</button>
// 重置store
const reset = () => {
  store.$reset();
};
6.4、批量更改state数据

ps:调用store的 $patch 方法

<button @click="patchStore">批量修改数据</button>
// 批量修改数据
const patchStore = () => {
  store.$patch({
    name: "张三",
    age: 100,
    sex: "女",
  });
};
6.5、直接替换整个state

ps:使用store的 $state 方法

store.$state = { counter: 666, name: '张三' }

7、getters

概念:getters 是 defineStore参数配置项里面的另一个属性,和Vue中的计算属性类似。

export const useUsersStore = defineStore("users", {
  state: () => {
    return {
      name: "小猪课堂",
      age: 25,
      sex: "男",
    };
  },
  getters: {
    getAddAge: (state) => {
      return state.age + 100;
    },
    getNameAndAge(): string {
      return this.name + this.getAddAge; // 调用其它getter
    },
  },
});

7.1、getter传参
getters: {
    getAddAge: (state) => {
      return (num) => state.age + num;
    },
  },

调用:<p>新年龄:{{ store.getAddAge(1100) }}</p>

8、actions

ps:actions属性值同样是一个对象,该对象里面也是存储的各种各样的方法,包括同步方法和异步方法,主要处理业务逻辑。

8.1、添加action
 actions: {
    saveName(name: string) {
      this.name = name;
    },
  },
8.2、调用action
const saveName = () => {
  store.saveName("我是小猪");
};

9、Pinia分模块

在pinia中一个ji / ts文件就是一个模块。

10、Pinia持久化存储

下载插件

npm i pinia-plugin-persist --save

全局配置

// main.ts
import { createPinia } from 'pinia'
// pinia持久化存储插件
import piniaPluginPersist from 'pinia-plugin-persist'
import App from './App.vue'
const pinia = createPinia();
// 将持久化存储挂载到pinia
pinia.use(piniaPluginPersist)
createApp(App).use(pinia).mount('#app')

使用

import { defineStore } from "pinia";

export const useStore = defineStore('storeId', {
  state() {
    return {
      num: 0,
      name: '张三',
      age: 20
    }
  },
  getters: { },
  actions: { },
  persist: {
    // 开启持久化存储,默认是sessionStorage
    enabled: true,
    strategies: [{
      // 持久化存储的key值
      key: 'myStore',
      // 配置为localStorage
      storage: localStorage,
      // 局部持久化,将需要持久化的数据加入到数组
      paths:['name']
    }]
  }
})

11、Pinia总结 - 三大点

  • state - 存储数据
  • getters - 处理数据
  • actions - 处理业务逻辑,同步异步都支持
### Pinia 的使用教程与常见开发方法 #### 1. **Pinia 基础概念** PiniaVue 3 中用于状态管理的新库,相较于 Vuex 更加轻量级且易于理解。它通过 Store 来集中管理应用的状态,并支持 TypeScript 类型推断[^1]。 #### 2. **安装与初始化** 在项目中引入并注册 Pinia 非常简单。首先需要安装 Pinia 库: ```bash npm install pinia ``` 接着在 `main.ts` 文件中完成 Pinia 的初始化和挂载操作: ```typescript // main.ts import { createApp } from 'vue'; import { createPinia } from 'pinia'; const app = createApp(App); const pinia = createPinia(); app.use(pinia); // 注册 Pinia app.mount('#app'); ``` 以上代码展示了如何将 Pinia 添加到 Vue 应用程序中[^1]。 #### 3. **定义 Store** 使用 `defineStore` 函数创建一个新的 Store。下面是一个简单的例子,展示了一个名为 `user` 的 Store,其中包含了用户的个人信息以及更新数据的方法: ```typescript // store/Store.ts import { defineStore } from 'pinia'; export const useUserStore = defineStore('userInfo', { state: () => ({ data: { id: '', name: '', token: '', email: '' } }), actions: { setData(payload: any) { this.data = payload; } } }); ``` 这段代码定义了一个 Store,包含初始状态和修改该状态的动作函数[^3]。 #### 4. **在组件中使用 Store** 组件可以通过调用之前定义好的 Store 方法来访问或更改全局状态。例如,在某个页面组件中设置用户信息如下所示: ```typescript <script setup lang="ts"> import { useUserStore } from '@/store/Store'; const userStore = useUserStore(); userStore.setData({ id: '123', name: 'John Doe', token: 'abcde...', email: 'john@example.com' }); </script> ``` 这里演示了如何实例化 Store 并调用其动作函数以改变共享的数据。 #### 5. **状态持久化** 若要使 Store 数据在页面刷新之后仍然存在,则可以借助第三方插件如 `pinia-plugin-persistedstate` 实现这一目标。以下是具体步骤说明: ##### 安装插件: ```bash npm install pinia-plugin-persistedstate ``` ##### 配置插件: ```typescript // main.ts import { createPinia } from 'pinia'; import piniaPluginPersistedstate from 'pinia-plugin-persistedstate'; const pinia = createPinia(); pinia.use(piniaPluginPersistedstate); app.use(pinia); ``` 这样就可以让指定的 Store 属性保存至本地存储或其他形式的缓存机制之中[^2]。 --- ###
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值