认识Vue新一代的状态管理库--Pinia
2022-11-27 21:09:48
223
{{single.collect_count}}
什么是pinia?怎么使用?本篇文章就来带大家了解一下Vue新一代的状态管理库--Pinia,希望对大家有所帮助!

前端(vue)入门到精通课程,老师在线辅导:联系老师
Apipost = Postman + Swagger + Mock + Jmeter 超好用的API调试工具:点击使用

什么是 Pinia

Pinia (西班牙语中的菠萝),本质上依然是一个状态管理的库,用于跨组件、页面进行状态共享。【相关推荐:vue.js视频教程

pinia 与 vuex 的区别:

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

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

  • 不再有modules的嵌套结构

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

如何使用 Pinia

1、安装 pinia

yarn add pinia
登录后复制

2、创建一个pinia

// src/stores/index.jsimport { createPinia } from "pinia";const pinia = createPinia()export default pinia
登录后复制
//main.jsimport pinia from './stores'app.use(pinia)
登录后复制

认识 Store

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

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

1. 定义一个store

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

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

image-20220812152348346

2. 使用 store

image-20220812152432057

image-20220812154916315

操作 State

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

image-20220812163115369

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

image-20220812165009960

image-20220812165858904

image-20220812170350560

image-20220812170540664

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 引入另外一个 gettersuseDebouleCount() {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中的GettersshowMessage(state) {// 获取user信息const useStore = useUser()// 获取自己的state// 拼接信息return `name:${useStore.name} - count:${state.count}`}}
登录后复制

image-20220812181122665

认识和定义 Action

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

image-20220813121159762

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

image-20220813121241994

更多编程相关知识,请访问:编程入门!!

以上就是认识Vue新一代的状态管理库--Pinia的详细内容,更多请关注php中文网其它相关文章!

回帖
全部回帖({{commentCount}})
{{item.user.nickname}} {{item.user.group_title}} {{item.friend_time}}
{{item.content}}
{{item.comment_content_show ? '取消' : '回复'}} 删除
回帖
{{reply.user.nickname}} {{reply.user.group_title}} {{reply.friend_time}}
{{reply.content}}
{{reply.comment_content_show ? '取消' : '回复'}} 删除
回帖
收起
没有更多啦~
{{commentLoading ? '加载中...' : '查看更多评论'}}