Vue状态管理库Pinia详细介绍

作者:贤蛋大眼萌 时间:2024-05-09 15:11:43 

什么是 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() 定义的,

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

Vue状态管理库Pinia详细介绍

使用 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详细介绍

认识和定义 Action

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

Vue状态管理库Pinia详细介绍

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

Vue状态管理库Pinia详细介绍

来源:https://blog.csdn.net/weixin_47980825/article/details/126317859

标签:Vue,Pinia,状态管理
0
投稿

猜你喜欢

  • 请给PNG8一个机会:对png8的误解

    2009-09-21 10:45:00
  • asp如何删除数据库中的表或索引?

    2010-06-26 12:23:00
  • 详解如何在vue项目中使用layui框架及采坑

    2024-04-09 10:58:35
  • mysql中如何设置大小写不敏感

    2024-01-15 08:10:43
  • mysql学习笔记之数据引擎

    2024-01-25 12:38:28
  • MacBook m1芯片采用miniforge安装python3.9的方法示例

    2022-03-03 21:18:26
  • linux下安装easy_install的方法

    2022-07-20 15:10:24
  • C#使用ODBC与OLEDB连接数据库的方法示例

    2024-01-12 17:41:41
  • Python3实现的判断回文链表算法示例

    2021-04-10 05:53:25
  • CentOS 6.5中安装Python 3.6.2的方法步骤

    2022-10-11 09:13:43
  • Python抽象类的新写法

    2022-12-04 13:39:38
  • Python3 全自动更新已安装的模块实现

    2022-02-26 15:54:11
  • Python淘宝秒杀的脚本实现

    2022-12-08 01:46:21
  • Pycharm2022最新版无法换源解决方法

    2023-02-09 20:51:55
  • Laravel 5使用Laravel Excel实现Excel/CSV文件导入导出的功能详解

    2024-05-03 15:29:17
  • python温度转换华氏温度实现代码

    2021-09-01 22:30:49
  • PHP中Http协议post请求参数

    2023-11-16 18:38:38
  • 怎么样才能让ASP避免被SQL注入啊?

    2008-08-08 12:27:00
  • Oracle过程与函数的区别分析

    2024-01-15 20:15:37
  • js判断手机和pc端选择不同执行事件的方法

    2024-04-29 13:45:46
  • asp之家 网络编程 m.aspxhome.com