状态管理Pinia

Vue3 状态管理 - Pinia

1. 什么是Pinia

Pinia 是 Vue 的专属的最新状态管理库 ,是 Vuex 状态管理工具的替代品

状态管理Pinia_第1张图片

2. 手动添加Pinia到Vue项目

后面在实际开发项目的时候,Pinia可以在项目创建时自动添加,现在我们初次学习,从零开始:

  1. 使用 Vite 创建一个空的 Vue3项目

npm init vite@latest
  1. 按照官方文档安装 pinia 到项目中

3. Pinia基础使用

  1. 定义store

  2. 组件使用store

状态管理Pinia_第2张图片

4. getters实现

Pinia中的 getters 直接使用 computed函数 进行模拟, 组件中需要使用需要把 getters return出去

状态管理Pinia_第3张图片

5. action异步实现

方式:异步action函数的写法和组件中获取异步数据的写法完全一致

  • 接口地址:http://geek.itheima.net/v1_0/channels

  • 请求方式:get

  • 请求参数:无

状态管理Pinia_第4张图片

需求:在Pinia中获取频道列表数据并把数据渲染App组件的模板中

状态管理Pinia_第5张图片

6. storeToRefs工具函数

使用storeToRefs函数可以辅助保持数据(state + getter)的响应式解构

状态管理Pinia_第6张图片

状态管理Pinia_第7张图片

7. Pinia的调试

Vue官方的 dev-tools 调试工具 对 Pinia直接支持,可以直接进行调试

状态管理Pinia_第8张图片

8. Pinia持久化插件

官方文档:Home | pinia-plugin-persistedstate

  1. 安装插件 pinia-plugin-persistedstate

npm i pinia-plugin-persistedstate
  1. 使用 main.js

import persist from 'pinia-plugin-persistedstate'
...
app.use(createPinia().use(persist))
  1. 配置 store/counter.js

import { defineStore } from 'pinia'
import { computed, ref } from 'vue'
​
export const useCounterStore = defineStore('counter', () => {
  ...
  return {
    count,
    doubleCount,
    increment
  }
}, {
  persist: true
})

状态管理Pinia_第9张图片

  1. 其他配置,看官网文档即可

你可能感兴趣的:(html5)