您现在的位置是:网站首页> 编程资料编程资料
Vue状态管理库Pinia详细介绍_vue.js_
2023-05-24
462人已围观
简介 Vue状态管理库Pinia详细介绍_vue.js_
什么是 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() 定义的,
- 且它需要一个唯一名称,作为第一个参数传递

使用 store


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

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




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}` } } 
认识和定义 Action
Action 可以理解成组件中的 methods ,和getters一样,在action中可以通过this访问整个store实例的所有操作。

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

到此这篇关于Vue状态管理库Pinia详细介绍的文章就介绍到这了,更多相关Vue Pinia内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:
相关内容
- element-ui tree 异步树实现勾选自动展开、指定展开、指定勾选功能_vue.js_
- 关于Vue-extend和VueComponent问题小结_vue.js_
- vue中关于redirect(重定向)初学者的坑_vue.js_
- element-plus 在vue3 中不生效的原因解决方法(element-plus引入)_vue.js_
- 关于路由重定向redirect的基本使用_vue.js_
- 一文详解如何清除手机上小程序缓存_javascript技巧_
- 利用React实现虚拟列表的示例代码_React_
- vue双向数据绑定指令v-model的用法_vue.js_
- vue动态绑定v-model属性名方式_vue.js_
- vue中render函数和h函数以及jsx的使用方式_vue.js_
