!
也想出现在这里? 联系我们
广告区块

【Vue全家桶】新一代的状态管理–Pinia

? 什么是 Pinia

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

pinia 与 vuex 的区别:

  1. 更友好的TypeScript支持,Vuex之前对TS的支持很不友好

  2. 与 Vuex 相比,Pinia 提供了一个更简单的 API,具有更少的仪式,提供了 Composition-API 风格的 API

  3. 不再有modules的嵌套结构

  4. 也不再有命名空间的概念,不需要记住它们的复杂关系

如何使用 Pinia

  1. 安装 pinia
yarn add pinia
  1. 创建一个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

1. 定义一个store

  • Store 是使用 defineStore() 定义的,

  • 且它需要一个唯一名称,作为第一个参数传递

【Vue全家桶】新一代的状态管理--Pinia

2. 使用 store

【Vue全家桶】新一代的状态管理--Pinia

【Vue全家桶】新一代的状态管理--Pinia

? 操作 State

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

【Vue全家桶】新一代的状态管理--Pinia

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

【Vue全家桶】新一代的状态管理--Pinia

【Vue全家桶】新一代的状态管理--Pinia

【Vue全家桶】新一代的状态管理--Pinia

【Vue全家桶】新一代的状态管理--Pinia

? 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}`
    }
  }
【Vue全家桶】新一代的状态管理--Pinia

【Vue全家桶】新一代的状态管理--Pinia

?认识和定义 Action

Action 可以理解成组件中的 methods ,和getters一样,在action中可以通过this访问整个store实例的所有操作。

【Vue全家桶】新一代的状态管理--Pinia

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

【Vue全家桶】新一代的状态管理--Pinia

【Vue全家桶】新一代的状态管理--Pinia

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_47980825/article/details/126317859
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
有新私信 私信列表
搜索