Vue状态管理库Pinia详细介绍

2022-10-14,

这篇文章主要介绍了Vue3-pinia状态管理,pinia是 vue3 新的状态管理工具,简单来说相当于之前 vuex,它去掉了 Mutations 但是也是支持 vue2 的,需要的朋友可以参考下

目录
  • 什么是 Pinia
    • 如何使用 Pinia
  • 认识 Store
    • 定义一个store
    • 使用 store
  • 操作 State
    • Getters
      • 1. 认识和定义 Getters
      • 2. 访问 Getters
    • 认识和定义 Action

      什么是 Pinia

      Pinia (西班牙语中的菠萝),本质上依然是一个状态管理的库,用于跨组件、页面进行状态共享.

      pinia 与 vuex 的区别:

      • 更友好的TypeScript支持,Vuex之前对TS的支持很不友好
      • 与 Vuex 相比,Pinia 提供了一个更简单的 API,具有更少的仪式,提供了 Composition-API 风格的 API
      • 不再有modules的嵌套结构
      • 也不再有命名空间的概念,不需要记住它们的复杂关系

      如何使用 Pinia

      安装 pinia

      yarn add pinia

      创建一个pinia

      // src/stores/index.js
      import { createPinia } from "pinia";
      const pinia = createPinia()
      export default pinia
      //main.js
      import pinia from './stores'
      app.use(pinia)

      认识 Store

      一个 Store (如 Pinia)是一个实体,它会持有为绑定到你组件树的状态和业务逻辑,也就是保存了全局的状态

      这样就可以定义任意数量的Store来管理你的状态,包括 state、getters、actions

      定义一个store

      • Store 是使用 defineStore() 定义的,
      • 且它需要一个唯一名称,作为第一个参数传递

      使用 store

      操作 State

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

      • 方式一:直接一个个修改state
      • 方式二:一次性修改多个状态
      • 方式三:替换state
      • 方式四:重置state

      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。

      到此这篇关于Vue状态管理库Pinia详细介绍的文章就介绍到这了,更多相关Vue Pinia内容请搜索北冥有鱼以前的文章或继续浏览下面的相关文章希望大家以后多多支持北冥有鱼!

      您可能感兴趣的文章:

      • 一文详解Pinia和Vuex与两个Vue状态管理模式
      • 详解Vue3-pinia状态管理
      • vue3-pinia-ts项目中的使用示例详解
      • vuex5中的Pinia插件机制
      • vue3+pinia的快速入门使用教程
      • Vue新一代状态管理工具Pinia的具体使用
      • vue中使用 pinia 全局状态管理的实现
      • Vue生态的新成员Pinia的详细介绍
      • Vue替代vuex的存储库Pinia详细介绍

      《Vue状态管理库Pinia详细介绍.doc》

      下载本文的Word格式文档,以方便收藏与打印。