当前位置:首页 » 《随便一记》 » 正文

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

24 人参与  2022年09月07日 11:07  分类 : 《随便一记》  评论

点击全文阅读


【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

安装 pinia
yarn 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() 定义的,

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

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

喜欢就一键三连吧!


点击全文阅读


本文链接:http://www.zhangshiyu.com/post/44871.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 无弹窗全文(许轻衣陆庭深)冷战两年,她离婚他发疯全文畅享阅读
  • 完结文爱如溺海恨意难休结局+番外免费列表_完结文爱如溺海恨意难休结局+番外免费(司漾许澄意柳眠眠)
  • 三国之召唤妖孽系统大反击_刘协精选作品_小说后续在线阅读_无删减免费完结_
  • 我盼孤身纵马,四海任我游在线阅读_蔺昭魏迟连蔺昭更新_小说后续在线阅读_无删减免费完结_
  • 终章小说姜挽宁段秉谦:结局+番外(愿负光阴也负你)已更新+延伸(愿负光阴也负你)清爽版
  • 奉命吃瓜后,我的瓜田遍布全世界是什么小说(云似初叶见深)(奉命吃瓜后,我的瓜田遍布全世界)全本完整清爽版在线+无广告结局
  • (姜挽宁段秉谦)姜挽宁段秉谦小说(愿负光阴也负你)小说全集速览无广告高口碑小说
  • 重生到末日高温前,被污蔑成荡妇的我自请下堂后续+完结_陈风婆婆林溪超长版_小说后续在线阅读_无删减免费完结_
  • 人家拿命下副本,你却用假身逃课?无错版_陈林连载_小说后续在线阅读_无删减免费完结_
  • 完结文犹若清风梦了云宝藏列表_完结文犹若清风梦了云宝藏(晏临渊叶知薇)
  • 儿子来自六年后:结局+番外免费品鉴:结局+番外评价五颗星
  • 完结文开挂辅助成团宠,全星际争当大冤种!结局+番外高口碑列表_完结文开挂辅助成团宠,全星际争当大冤种!结局+番外高口碑(白希薇)

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1