【Vue全家桶】新一代的状态管理--Pinia
? 什么是 Pinia如何使用 Pinia ?认识 Store1. 定义一个store2. 使用 store ? 操作 State? Getters1. 认识和定义 Getters2. 访问 Getters ?认识和定义 Action
? 什么是 Pinia
Pinia (西班牙语中的菠萝),本质上依然是一个状态管理的库,用于跨组件、页面进行状态共享.
pinia 与 vuex 的区别:
更友好的TypeScript支持,Vuex之前对TS的支持很不友好
与 Vuex 相比,Pinia 提供了一个更简单的 API,具有更少的仪式,提供了 Composition-API 风格的 API
不再有modules的嵌套结构
也不再有命名空间的概念,不需要记住它们的复杂关系
如何使用 Pinia
安装 piniayarn add pinia// src/stores/index.jsimport { createPinia } from "pinia";const pinia = createPinia()export default pinia//main.jsimport pinia from './stores'app.use(pinia)?认识 Store
一个 Store (如 Pinia)是一个实体,它会持有为绑定到你组件树的状态和业务逻辑,也就是保存了全局的状态
这样就可以定义任意数量的Store来管理你的状态,包括 state、getters、actions
1. 定义一个store
Store 是使用 defineStore() 定义的,
且它需要一个唯一名称,作为第一个参数传递

2. 使用 store


? 操作 State
state 是 store 的核心部分,store是用来实现我们管理状态的。





? Getters
1. 认识和定义 Getters
Getters相当于Store的计算属性:
可以用 defineStore() 中的 getters 属性定义;getters中可以定义接受一个state作为参数的函数;2. 访问 Getters
方式一:访问当前 store 的Getters
方式二:Getters 中访问自己的其他Getters
方式三:访问其他的 store 的Getters
getters: {    // 1. 基本使用    debouleCount(state) {      return state.count * 2    },    // 2. 一个 getters 引入另外一个 getters    useDebouleCount() {      return this.debouleCount + 2    },    // 3. getter也支持返回一个函数    getFriendById(state) {      return function (id) {        for (let i = 0; i < state.vagetabel.length; i++) {          const vagetabel = state.vagetabel[i]          if (vagetabel.id === id) {            return vagetabel          }        }      }    },    // 4.访问其他store中的Getters    showMessage(state) {      // 获取user信息      const useStore = useUser()      // 获取自己的state      // 拼接信息      return `name:${useStore.name} - count:${state.count}`    }  }
?认识和定义 Action
Action 可以理解成组件中的 methods ,和getters一样,在action中可以通过this访问整个store实例的所有操作。

Action 是支持异步操作的,所以可以使用 await。

