Vue新一代的状态管理库Pinia怎么使用

发布时间:2022-08-31 10:10:12 作者:iii
来源:亿速云 阅读:194

今天小编给大家分享一下Vue新一代的状态管理库Pinia怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

什么是 Pinia

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

pinia 与 vuex 的区别:

如何使用 Pinia

1、安装 pinia

yarn add pinia

2、创建一个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

Vue新一代的状态管理库Pinia怎么使用

2. 使用 store

Vue新一代的状态管理库Pinia怎么使用

Vue新一代的状态管理库Pinia怎么使用

操作 State

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

Vue新一代的状态管理库Pinia怎么使用

Vue新一代的状态管理库Pinia怎么使用

Vue新一代的状态管理库Pinia怎么使用

Vue新一代的状态管理库Pinia怎么使用

Vue新一代的状态管理库Pinia怎么使用

Getters

1. 认识和定义 Getters

Getters相当于Store的计算属性:

2. 访问 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怎么使用

以上就是“Vue新一代的状态管理库Pinia怎么使用”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。

推荐阅读:
  1. 在react中如何使用vue的状态管理
  2. 使用vue怎么实现状态管理

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

vue pinia

上一篇:redis分布式锁如何优化

下一篇:MySQL子查询如何使用

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》