目录
什么是 Pinia
如何使用 Pinia
认识 Store
1. 定义一个store
2. 使用 store
操作 State
Getters
1. 认识和定义 Getters
2. 访问 Getters
认识和定义 Action
首页 web前端 Vue.js 认识Vue新一代的状态管理库--Pinia

认识Vue新一代的状态管理库--Pinia

Aug 30, 2022 pm 07:56 PM
vue vue3 状态管理 pinia

什么是pinia?怎么使用?本篇文章就来带大家了解一下Vue新一代的状态管理库--Pinia,希望对大家有所帮助!

认识Vue新一代的状态管理库--Pinia

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

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

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 引入另外一个 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}`
    }
  }
登录后复制

image-20220812181122665

认识和定义 Action

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

image-20220813121159762

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

image-20220813121241994

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

以上是认识Vue新一代的状态管理库--Pinia的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

vue中echarts怎么用 vue中echarts怎么用 May 09, 2024 pm 04:24 PM

vue中echarts怎么用

vue中的export default的作用 vue中的export default的作用 May 09, 2024 pm 06:48 PM

vue中的export default的作用

vue中map函数的用法 vue中map函数的用法 May 09, 2024 pm 06:54 PM

vue中map函数的用法

vue中event和$event区别 vue中event和$event区别 May 08, 2024 pm 04:42 PM

vue中event和$event区别

vue中export与export default区别 vue中export与export default区别 May 08, 2024 pm 05:27 PM

vue中export与export default区别

vue中onmounted作用 vue中onmounted作用 May 09, 2024 pm 02:51 PM

vue中onmounted作用

vue中的事件修饰符可以用于哪些场景 vue中的事件修饰符可以用于哪些场景 May 09, 2024 pm 02:33 PM

vue中的事件修饰符可以用于哪些场景

vue中的钩子是什么 vue中的钩子是什么 May 09, 2024 pm 06:33 PM

vue中的钩子是什么

See all articles