首页IT科技vue状态管理使用(【Vue全家桶】新一代的状态管理–Pinia)

vue状态管理使用(【Vue全家桶】新一代的状态管理–Pinia)

时间2025-09-18 08:47:51分类IT科技浏览5165
导读:🍳作者: 贤蛋大眼萌,一名很普通但不想普通的程序媛...

🍳作者:

贤蛋大眼萌                 ,一名很普通但不想普通的程序媛

\color{#FF0000}{贤蛋 大眼萌                           ,一名很普通但不想普通的程序媛}

贤蛋大眼萌        ,一名很普通但不想普通的程序媛🤳

🙊语录:

多一些不为什么的坚持

\color{#0000FF}{多一些不为什么的坚持}

多一些不为什么的坚持

📝本文章收录于专栏:Vue框架

💭

眼过千遍不如手锤一遍:推荐一款模拟面试         ,斩获大厂

o

f

f

e

r

                          ,程序员的必备刷题平台

牛客网

\color{#ff7f50}{眼过千遍不如手锤一遍:推荐一款模拟面试                 ,斩获大厂offer         ,程序员的必备刷题平台--牛客网}

眼过千遍不如手锤一遍:推荐一款模拟面试                          ,斩获大厂offer                 ,程序员的必备刷题平台牛客网

👉🏻点击跳转刷题网免费注册学习

🦴 什么是 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

1. 定义一个store

Store 是使用 defineStore() 定义的         ,

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

2. 使用 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        。

PS:

求知无坦途,学问无捷径         。👣

一步一个脚印                          ,你走过的路                          ,每一步都算数                          。

\color{#ff7f50}{一步一个脚印,你走过的路                 ,每一步都算数                 。}

一步一个脚印                          ,你走过的路        ,每一步都算数         。 每一次进步都是对自己努力的肯定                          。如果读了文章有收获                 ,不如一起来学习                          ,一起进步吧                 。传送门🚪刷题神器
声明:本站所有文章        ,如无特殊说明或标注         ,均为本站原创发布。任何个人或组织                          ,在未征得本站同意时                 ,禁止复制                  、盗用                          、采集        、发布本站内容到任何网站         、书籍等各类媒体平台                          。如若本站内容侵犯了原著者的合法权益         ,可联系我们进行处理                          。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
linux鼠标光标怎么改(Kali Linux鼠标怎么设置左撇子模式? Linux鼠标左手操作的选择方法) 可以赚钱的社交平台(如何能找到赚钱的游戏-适合社恐女生的5个简单副业,一个人安静挣钱就够了)