位置: IT常识 - 正文

【Vue全家桶】新一代的状态管理--Pinia(vue全家桶教程)

编辑:rootadmin
【Vue全家桶】新一代的状态管理--Pinia

推荐整理分享【Vue全家桶】新一代的状态管理--Pinia(vue全家桶教程),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue全家桶介绍,vue全家桶插件有哪些,vue全家桶介绍,vuex全家桶,vue全家桶的app项目代码,浅谈一下vue全家桶,vue全家桶插件有哪些,vue2.0全家桶,内容如对您有帮助,希望把文章链接给更多的朋友!

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

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

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

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

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

【Vue全家桶】新一代的状态管理--Pinia🦴 什么是 Pinia如何使用 Pinia🌂认识 Store1. 定义一个store2. 使用 store🧳 操作 State🍨 Getters1. 认识和定义 Getters2. 访问 Getters🍳认识和定义 Action🦴 什么是 Pinia

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

pinia 与 vuex 的区别:

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

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

不再有modules的嵌套结构

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

如何使用 Pinia安装 piniayarn add pinia创建一个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() 定义的,

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

【Vue全家桶】新一代的状态管理--Pinia(vue全家桶教程)

2. 使用 store

🧳 操作 State

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

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

🍨 Getters1. 认识和定义 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}{一步一个脚印,你走过的路,每一步都算数。}一步一个脚印,你走过的路,每一步都算数。 每一次进步都是对自己努力的肯定。如果读了文章有收获,不如一起来学习,一起进步吧。传送门🚪刷题神器

本文链接地址:https://www.jiuchutong.com/zhishi/300064.html 转载请保留说明!

上一篇:使用Vue脚手架配置代理服务器的两种方式(vue脚手架配合springsecurity)

下一篇:ChatGPT火爆来袭,携手参与为开源助力

  • 营业外收入需要缴纳什么税
  • 个体户定额超了怎么收费
  • 不动产租赁税率9%
  • 超市小票能否入库
  • 期初和期末余额均在借方的账户,一般属于
  • 如何查看发票是否被抵扣
  • 个税系统设置在哪里
  • 工会经费的工资薪金总额包括保险吗
  • 小规模纳税人增值税怎么算
  • 建筑企业异地预交税款如何处理
  • 盘盈的存货一般作为什么处理
  • 房地产开发企业资质等级有几个
  • 增值税普通发票怎么开
  • 发票种类和适用范围
  • 哪些科目需要计提资产减值损失
  • 不能确认收入的应收账款怎么做账
  • 未按期预缴企业个税
  • 增值税转售行为怎么做会计处理?
  • 没有增值税发票怎么出口
  • 销项税额与进项税额区别
  • 财政返还政策
  • 发票联给错怎么办?
  • 营改增后建筑业分包怎么交税
  • 收到汇算清缴退税的现金流量
  • 交易性金融资产属于流动资产吗
  • 贸易企业出口退税的操作明细流程
  • 汇兑损益怎么记账
  • 工会举办的比赛有哪些
  • 代开专用发票的流程资料要求
  • 企业销售货物收到价款5000元这笔经济业务属于
  • 发票开错的常见情况和处理办法?
  • 短视频小程序源码
  • 现金流量表补充资料怎么理解
  • js进阶视频教程
  • 勘察设计四个阶段
  • Yii2针对游客、用户防范规则和限制的解决方法分析
  • 新会计准则增加了哪些科目
  • 研发费用的范围和加计扣除比例
  • 开票是否享受优惠
  • 哪些情况属于
  • 企业银行存款的利息收入计入财务费用的借方A对B错
  • 广告公司工程部
  • 个体工商户定期定额怎么报税
  • 走账犯罪吗
  • 在建工程的成本包括应交增值税吗
  • 办公设备维修费会计分录
  • 企业设备融资是什么意思?
  • 公司注销其他应付款法人借款
  • 报销核销
  • 公司报销给个人的会计分录
  • 小规模其他业务收入交多少税率
  • 业务招待费会计科目
  • 规范专户资金使用
  • 小规模普票收入要交税吗
  • mac设置多个桌面
  • linux进程管理器
  • freebsd中文手册
  • 桌面快捷方式不显示图标怎么办
  • windows注册表保存在BIOS
  • 如何配置linux
  • dyservice.exe是什么
  • xp电脑注册表怎么打开
  • xp怎么改w7
  • windows8.1开始
  • cocos2dx 地图
  • java多线程最佳实践
  • django的工作原理
  • 批处理计数
  • 浅析科学发展观的核心立场
  • 如何使用nodejs
  • jquery的实现原理
  • 如何做好设计师
  • python怎么用命令行
  • js跨域的几种方法
  • jquery插件大全
  • 如何动态加载外部文件
  • 发票被暂停了严重吗
  • 福州税务实名认证
  • 企业资质怎么报审
  • 推动税务系统全面从严
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设