Vue3.0 状态管理库Pinia的核心属性

关于Pinia

如果你之前使用过Vue2.0的状态管理Vuex,那么上手Pinia将会变的十分简单

核心部分 Store

  1. store是一个保存状态和业务逻辑的实体,它并不与你的组件树绑定;换句话说,它承载着全局状态;它有点像一个永远存在的组件,每个组件都可以读取和写入它
  2. store它有三个概念,stategettersactions,我们可以l理解成组件中的datacomputedmethods
  3. 在项目中的src\store文件夹下不同的store.js文件
  4. store是用defineStore(name, function | options)定义的,建议其函数返回的值命名为use…Store方便理解
    a. 参数name:名字,必填值且唯一
    b. 参数function|options:可以是对象或函数形式
    ■ 对象形式【选项模式】,其中配置state、getters和actions选项
    ■ 函数形式【组合模式,类似组件组合式API的书写方式】,定义响应式变量和方法,并且return对应的变量和方法;ref()相当于state,computed()相当于getters,function()相当于actions

Store中的State

state是store的核心部分,主要存储的是共享的数据

  • . store采用的是选项式模式时,state选项为函数返回的对象,在其定义共享的数据
  • . store采用的是组合式模式时,在其函数内定义的ref变量,最终return出去来提供共享的数据
// 这里举例都用组合式api
import {
   
   defineStore} from "pinia";
import {
   
   ref} from "vue";

export const useUserStore = defineStore('user', () => {
   
   
    const age = ref(27)
    const level = ref(5)
    const account = ref('SD77842')
    const nickname = ref('二十四桥明月夜')
    
    return {
   
    age, level, account, nickname } // 将数据暴露出去,共享给需要的组件
})

组件中访问State

  1. 在选项式 API 组件中,可以使用mapState(storeObj, array | object)帮助器将状态属性映射为只读计算属性
    a. storeObj引入的store对象
    b. array | object:字符串数组形式或者对象形式
    ■ 【字符串数组形式】直接将store中state的数据映射为当前组件的计算属性,但是不能自定义名称
    ■ 【对象形式时】key为自定义当前组件的计算属性名,value字符串形式,是store中state的共享数据
    提示:mapState()函数映射到组件中的计算属性是只读的,如果想在组件中响应式修改state的数据,则应该选择mapWritableState()函数来映射计算属性
  2. 在组合式 API 组件中,直接引入对应的store,通过store对象直接获取和修改state
    提示:
    如果想在组件中自定义变量来接收store中的state中共享的数据,我们可以这样做:
    ● 使用computed(() => store.dataName),具有响应式,但是只读形式
    ● 使用storeToRefs(store)从store解构想要的state,具有响应式,可直接修改,可自定义名称
<script setup>
import {
   
    useUserStore } from "@/stores/counter.js";
import {
   
    storeToRefs } from 
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值