vuex新手进阶篇之actions的使用方法

作者:Jay丶千珏 时间:2024-04-27 16:13:54 

紧接上篇文章,本篇文章讲vuex ,如何去改变state ,actions的使用,我依然使用了vuex的modules

1.设置actions事件

index.js

vuex新手进阶篇之actions的使用方法

dict.js

vuex新手进阶篇之actions的使用方法

2.在组件中去分发actions

<template>
 <div>
   <div>
     改变vuex index.js 下的state
     <div>
       {{ $store.state.userInfo.name + "---" + $store.state.userInfo.age }}
     </div>
     <div>
       <button @click="changeUserInfo">修改方式1</button>
     </div>
     <div>
       <button @click="changeUserInfo2">修改方式2</button>
     </div>
   </div>

--------------------------------------------------

<div>
     改变vuex index.js modules下的dict 下的state
     <div>
       {{ $store.state.dict.taskTypeDict }}
     </div>
     <div>
       <button @click="changeDict">修改方式1</button>
     </div>
     <div>
       <button @click="changeDict2">修改方式2</button>
     </div>
   </div>
 </div>
</template>

<script>
import { mapActions } from "vuex"; //方式二 1.首先引入
export default {
 methods: {
   //   方式一,dispatch分发事件
   changeUserInfo() {
     this.$store.dispatch("getUserInfo");
   },
   // 方式二
   ...mapActions(["getUserInfo2"]), //2.使用mapActions函数将组件的 methods 映射为 store.dispatch 调用
   changeUserInfo2() {
     this.getUserInfo2(); //3.调用
   },
   // -------------------------------------------------------------------------------------------
   //因为我们在modules下开启了命名空间,所以我们在调用dict下的Actions时,需在前方加上空间名字
   changeDict() {
     this.$store.dispatch("dict/getTaskTypeDict");
   },
   //因为我们开辟了命名空间,故需要重写一个方法名,进行承接映射,注意此处不再是数组,而是一个对象
   ...mapActions({ getDicts: "dict/getTaskTypeDict2" }),
   changeDict2() {
     this.getDicts();
   },
 },
};
</script>

3.注意点

action 类似于 mutation,不同在于

1.action 提交的是 mutation事件,而不是直接去改变state的状态值,改变state的值只有通过mutation

2.action 可以包含任意异步操作

actions的细节补充

1.参数问题

2.context的其他属性

3.另外一种提交风格(见上以对象的形式进行分发)

//store的index.js中
actions: {
   // 放函数
   // 1.参数问题
   incrementAction(context, payload) {
     console.log(payload)
     setTimeout(() => {
       context.commit('increment')
     }, 1000);
   },
   // 2.context的其他属性
   decrementAction({ commit, dispatch, state, rootState, getters, rootGetters }) {
     commit("decrement")
   }
 }

 

来源:https://blog.csdn.net/qq_42543244/article/details/118225352

标签:vuex,actions
0
投稿

猜你喜欢

  • 用Python实现插值算法

    2021-07-16 11:01:22
  • MySQL分库分表后路由策略设计详情

    2024-01-19 01:24:55
  • python基础之错误和异常处理

    2021-07-28 05:46:15
  • golang 输出重定向:fmt Log,子进程Log,第三方库logrus的详解

    2024-04-27 15:40:14
  • Python中super().__init__()测试以及理解

    2023-08-25 02:22:04
  • MySQL中把varchar类型转为date类型方法详解

    2024-01-27 03:15:01
  • 小学生也能看懂的Golang异常处理recover panic

    2024-02-08 20:32:36
  • Django瀑布流的实现示例

    2021-05-09 10:07:42
  • 给Linux定时备份数据库的实现脚本

    2024-01-15 09:15:22
  • Python基于随机采样一至性实现拟合椭圆(优化版)

    2021-10-19 15:08:36
  • mysql 8.0.22.0 下载安装配置方法图文教程

    2024-01-24 14:14:36
  • php中strtotime函数性能分析

    2023-11-22 13:21:05
  • 详解Vue.js 可拖放文本框组件的使用

    2024-04-27 15:47:22
  • 利用python绘制中国地图(含省界、河流等)

    2021-12-19 03:19:59
  • 探索网页设计中的黄金比例

    2008-10-20 12:26:00
  • 详解python变量与数据类型

    2021-09-24 14:38:32
  • 最新整理Python中的type和object的示例详解

    2023-08-10 05:21:44
  • Python控制浏览器自动下载歌词评论并生成词云图

    2022-04-17 11:24:56
  • MAC 中mysql密码忘记解决办法

    2024-01-18 04:13:48
  • JS与jQuery判断文本框还剩多少字符可以输入的方法

    2024-04-25 13:07:20
  • asp之家 网络编程 m.aspxhome.com