Vue3-47-Pinia-修改全局状态变量值的方式

说明

修改全局状态变量的值,是一个比较常规而且常见的操作。

本文就介绍四种常见的操作。

由于Option StoreSetup Store 在修改的时候略有不同,所以本文也会将不同点体现一下。

全局状态变量的定义

包含了 Option StoreSetup Store 两种定义方式;

在下面的修改操作中会根据这两种不同的定义来分别阐述。

ts 复制代码
// 导入 defineStore API
import { defineStore } from 'pinia'

// 导入 reactive 依赖
import { reactive } from 'vue'

// 定义全局状态方式一 : option store
export const useClassStore = defineStore('classinfo',{

    state: () => ({
        name:'快乐篮球二班',
        studentNum:30
    }),

    actions:{
      // 用来更新状态的值
      updateName(){
        this.name = '使用actions修改的name'
      }
    }


})

// 定义全局状态方式二 : setup store
export const useStudentStore = defineStore('studentinfo',() => {

    // 响应式状态
    const student =  reactive({
        name : '小明',
        age:12,
        className:'快乐足球一班'
    })


    // 直接定义一个方法进行数据属性的修改
    const updateName = (nameP:string)=>{
        student.name = nameP
    }


    return { student,updateName }

})

方式一 : 直接修改

直接修改 : 就是直接读取对象进行变量值的替换。

Option Store

ts 复制代码
	// 导入全局状态变量的定义
    import  { useClassStore }  from './storea'

    // 获取全局状态变量的对象
    const classStore = useClassStore()

    // 方式一 : 直接修改
   classStore.studentNum = 36

Setup Store

ts 复制代码
	// 导入全局状态变量的定义
    import  { useStudentStore }  from './storea'

    // 获取全局状态变量的对象
    const studentStore = useStudentStore()
    
    // 方式一 : 直接修改
    studentStore.student.className = '我也不知道是哪个班的'

方式二 :$patch 方式修改

参数是一个对象的形式

Option Store

直接放入 【参数对象】 : {key:value} 就OK了

ts 复制代码
	// 导入全局状态变量的定义
    import  { useClassStore }  from './storea'

    // 获取全局状态变量的对象
    const classStore = useClassStore()
    
  	// 方式二 : $patch 方法修改
    classStore.$patch({studentNum:20})

Setup Store

由于 状态变量在定义的时候,就是一个响应式对象,所以需要把整个的对象都放进去才OK。

ts 复制代码
	// 导入全局状态变量的定义
    import  { useStudentStore }  from './storea'

    // 获取全局状态变量的对象
    const studentStore = useStudentStore()
    
    // 方式二 : $patch 方法修改
    studentStore.$patch({student:{
            name: studentStore.student.name,
            age: studentStore.student.age,
            className:'又换了一个班级'
    }})

方式三 : $patch 带参数的方式修改

参数是 函数的形式,且函数的参数就是 原state对象

这种方式用起来比【方式二】要更加灵活。

Option Store

ts 复制代码
	// 导入全局状态变量的定义
    import  { useClassStore }  from './storea'

    // 获取全局状态变量的对象
    const classStore = useClassStore()
    
   // 方式三 :$patch + 函数参数的方法修改 : 函数的参数就是 状态对象
   classStore.$patch((state)=>{
           console.log(state)
           state.studentNum = 100
   })

Setup Store

ts 复制代码
	// 导入全局状态变量的定义
    import  { useStudentStore }  from './storea'

    // 获取全局状态变量的对象
    const studentStore = useStudentStore()
    
    // 方式三 :$patch + 函数参数的方法修改 : 函数的参数就是 状态对象
    studentStore.$patch((state)=>{
         console.log(state)
         state.student.className = '超级无敌快乐踢足球的班'
    })

方式四 :actions方法的方式进行修改

这种方式比较好理解,就是通过调用已经定义好的方法的方式来进行变量值的修改。

也比较推荐使用这一种方式。

Option Store

ts 复制代码
	// 导入全局状态变量的定义
    import  { useClassStore }  from './storea'

    // 获取全局状态变量的对象
    const classStore = useClassStore()

 	// 方式四 :actions 方法的方式进行数据的修改
    classStore.updateName()

Setup Store

ts 复制代码
	// 导入全局状态变量的定义
    import  { useStudentStore }  from './storea'

    // 获取全局状态变量的对象
    const studentStore = useStudentStore()

    // 方式四 :actions 方法的方式进行数据的修改
    studentStore.updateName('小红')
相关推荐
知识分享小能手5 分钟前
Vue3 学习教程,从入门到精通,Axios 在 Vue 3 中的使用指南(37)
前端·javascript·vue.js·学习·typescript·vue·vue3
伍哥的传说30 分钟前
Mitt 事件发射器完全指南:200字节的轻量级解决方案
vue.js·react.js·vue3·mitt·组件通信·事件管理·事件发射器
尚学教辅学习资料6 小时前
Vue3从入门到精通:5.2 Vue3构建工具与性能优化深度解析
性能优化·vue3·入门到精通
加班是不可能的,除非双倍日工资1 天前
css预编译器实现星空背景图
前端·css·vue3
har01d6 天前
【CSS3】录音中。。。
前端·css·vue.js·vue·vue3·css3
知识分享小能手6 天前
Vue3 学习教程,从入门到精通,Vue 3 + Tailwind CSS 全面知识点与案例详解(31)
前端·javascript·css·vue.js·学习·typescript·vue3
青柠代码录15 天前
【ElementPlus】深入探索ElementPlus:前端界面的全能组件库
前端·vue3·elementplus
知识分享小能手17 天前
Vue3 学习教程,从入门到精通,Vue3 中使用 Axios 进行 Ajax 请求的语法知识点与案例代码(23)
前端·javascript·vue.js·学习·ajax·vue·vue3
咔咔一顿操作17 天前
Vue 3 入门教程7 - 状态管理工具 Pinia
前端·javascript·vue.js·vue3
汪叽家的兔子羡19 天前
vue模块化导入
前端·javascript·vue.js·typescript·vue3·vue2·vite