vue3使用Pinia修改state的三种方法(直接修改,$patch,actions)

 更新时间:2024年03月13日 09:56:45   作者:Jay丶萧邦  
Vue3 Pinia是一个状态管理库,专门为Vue3设计优化,它提供了一种简单而强大的方式来管理应用程序的状态,并且与Vue3的响应式系统紧密集成,本文给大家介绍了vue3使用Pinia修改state的三种方法,需要的朋友可以参考下

本篇记录vue3 使用pinia修改state的三种方法

1. 新建vue3项目,安装Pinia(参考链接:Vue状态管理工具Pinia的安装与使用教程_vue.js_脚本之家 (jb51.net))

2.目录

app.js

import {defineStore} from "pinia"
 
const appStore = defineStore('appStore', {
    state: () => ({
        baseUrl: 'https://www.baidu.com/',
        ipList: ['192.168.10.777', '192.168.10.999', '192.168.10.888']
    }),
    actions: {
        changeState(params) {
            console.log('接收到的参数===>', params)
            this.baseUrl = params
            this.ipList.push('192.168.10.100')
        }
    }
})
 
export default appStore

第一种修改方式:直接state = '数据'  ,不推荐

    const store = appStore()
    let {baseUrl, ipList} = storeToRefs(store)
 
    /*
    *  第一种修改方式:虽然可以直接修改,但是出于代码结构来说,
    *               全局的状态管理还是不要直接在各个组件处随意修改状态,
    *               应放于 action 中统一方法修改(piain没有mutation)
    *               并不推荐!!!
    * */
    function changeData() {
      // baseUrl = 'https://www.taobao.com/'  //error 这么写是没有用的
      store.baseUrl = 'https://www.taobao.com/'  //success
      store.ipList.push('192.168.10.111')  //success
    }

第二种修改方式:使用$patch修改数据

    const store = appStore()
    // 第二种修改方式:使用$patch改变数据 $patch 可以同时修改多个值
    function changeDataByPatch() {
      /*
      $patch也有两种的调用方式
      第一种写法的在修改数组时,假如我只想要把 ipList 的中第2项改成‘192.168.10.222',
      但是也需要传入整个包括所有元素的数组,这无疑增加了书写成本和风险,显然是不合理的,所以一般都推荐使用第二种传入一个函数的写法
      * */
      // 第一种 $patch方法
      // store.$patch({
      //   baseUrl: 'https://www.jd.com/',
      //   ipList: ['192.168.10.777', '192.168.10.222', '192.168.10.888']
      // })
 
      // 第二种 $patch方法
      store.$patch((state) => {
        state.baseUrl = 'https://www.jd.com/'
        state.ipList[0] = '192.168.10.222'
      })
    }

第三种修改方式:使用actions中的方法修改数据 (推荐)

    // 第三种修改方式:调用store中的action改变数据
    function changeDataByAction() {
      store.changeState('https://www.alibabagroup.com/cn/global/home')  //可以直接给actions里面的方法传递参数
    }

以上就是使用pinia修改数据的三种方法

pinia重置数据的功能,这个操作很简单

    const store = appStore()
    // 重置数据
    function resetData() {
      store.$reset()
    }

完整代码:

<template>
  <div>
    <strong>baseUrl:</strong>
    {{ baseUrl }}
  </div>
  <div>
    <strong>ipList:</strong>
    {{ ipList }}
  </div>
  <div>
    <button @click="changeData">直接在页面组件中改变数据</button>
    <button @click="changeDataByPatch">使用$patch改变数据</button>
    <button @click="changeDataByAction">使用action改变数据</button>
    <button @click="resetData">重置数据</button>
  </div>
</template>
 
<script>
import appStore from "@/store/app"
import {storeToRefs} from "pinia"
 
export default {
  name: "Home",
  setup() {
    const store = appStore()
    let {baseUrl, ipList} = storeToRefs(store)
 
    /*
    *  第一种修改方式:虽然可以直接修改,但是出于代码结构来说,
    *               全局的状态管理还是不要直接在各个组件处随意修改状态,
    *               应放于 action 中统一方法修改(piain没有mutation)
    *               并不推荐!!!
    * */
    function changeData() {
      // baseUrl = 'https://www.taobao.com/'  //error 这么写是没有用的
      store.baseUrl = 'https://www.taobao.com/'  //success
      store.ipList.push('192.168.10.111')  //success
    }
 
    // 第二种修改方式:使用$patch改变数据 $patch 可以同时修改多个值
    function changeDataByPatch() {
      /*
      $patch也有两种的调用方式
      第一种写法的在修改数组时,假如我只想要把 ipList 的中第2项改成‘192.168.10.222',
      但是也需要传入整个包括所有元素的数组,这无疑增加了书写成本和风险,显然是不合理的,所以一般都推荐使用第二种传入一个函数的写法
      * */
      // 第一种 $patch方法
      // store.$patch({
      //   baseUrl: 'https://www.jd.com/',
      //   ipList: ['192.168.10.777', '192.168.10.222', '192.168.10.888']
      // })
 
      // 第二种 $patch方法
      store.$patch((state) => {
        state.baseUrl = 'https://www.jd.com/'
        state.ipList[0] = '192.168.10.222'
      })
    }
 
    // 第三种修改方式:调用store中的action改变数据
    function changeDataByAction() {
      store.changeState('https://www.alibabagroup.com/cn/global/home')  //可以直接给actions里面的方法传递参数
    }
 
    // 重置数据
    function resetData() {
      store.$reset()
    }
 
    return {
      baseUrl,
      ipList,
      changeData,
      changeDataByPatch,
      changeDataByAction,
      resetData
    }
  }
}
</script>

以上就是vue3使用Pinia修改state的三种方法(直接修改,$patch,actions)的详细内容,更多关于vue3 Pinia修改state的资料请关注脚本之家其它相关文章!

相关文章

  • vue使用mui遇到的坑及解决

    vue使用mui遇到的坑及解决

    这篇文章主要介绍了vue使用mui遇到的坑及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • Vue中的 ref,props,mixin属性

    Vue中的 ref,props,mixin属性

    这篇文章主要介绍了Vue中的ref,props,mixin属性,文章围绕主题ref,props,mixin展开详细内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-05-05
  • 如何用 Deepseek 写的uniapp血型遗传查询工具

    如何用 Deepseek 写的uniapp血型遗传查询工具

    在现代社会中,了解血型遗传规律对于优生优育、医疗健康等方面都有重要意义,本文将介绍如何使用Uniapp开发一个跨平台的血型遗传查询工具,帮助用户预测孩子可能的血型,感兴趣的朋友一起看看吧
    2025-04-04
  • Vue路由组件传递参数的六种场景

    Vue路由组件传递参数的六种场景

    在Vue应用程序中,路由组件是构建单页应用的关键部分,传递参数给路由组件可以让我们动态地展示内容,处理用户输入,以及实现各种交互功能,本文就给大家介绍了六种Vue路由组件传递参数场景,需要的朋友可以参考下
    2023-09-09
  • 在Vue当中同时配置多个路由文件的方法案例代码

    在Vue当中同时配置多个路由文件的方法案例代码

    这篇文章主要介绍了在Vue当中同时配置多个路由文件的方法,包含具体代码,本文分步骤结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-12-12
  • elementui el-table中如何给表头 el-table-column 加一个鼠标移入提示说明

    elementui el-table中如何给表头 el-table-column 加一个鼠

    本文通过实例代码介绍如何在使用Element UI的el-table组件时为表头添加提示功能,通过结合el-tooltip组件实现鼠标移入时显示提示信息,感兴趣的朋友跟随小编一起看看吧
    2024-11-11
  • 使用Webpack提升Vue.js应用程序的4种方法(翻译)

    使用Webpack提升Vue.js应用程序的4种方法(翻译)

    这篇文章主要介绍了使用Webpack提升Vue.js应用程序的4种方法(翻译),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • Vue3格式化Volar报错的原因分析与解决

    Vue3格式化Volar报错的原因分析与解决

    Volar 与vetur相同,volar是一个针对vue的vscode插件,下面这篇文章主要给大家介绍了关于Vue3格式化Volar报错的原因分析与解决方法,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2022-06-06
  • vue实现登录数据的持久化的使用示例

    vue实现登录数据的持久化的使用示例

    在Vue.js中,实现登录数据的持久化需要使用浏览器提供的本地存储功能,Vue.js支持使用localStorage和sessionStorage来实现本地存储,本文就来介绍一下如何实现,感兴趣的可以了解一下
    2023-10-10
  • vue 计时器组件的实现代码

    vue 计时器组件的实现代码

    本篇文章主要介绍了vue 计时器组件的实现代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09

最新评论