如何高效运用Vuex的mutations进行复杂state的改变?

2026-04-02 08:391阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计686个文字,预计阅读时间需要3分钟。

如何高效运用Vuex的mutations进行复杂state的改变?

目录

1.设置修改state的mutations事件

2.提交mutations事件(常用的两种方法)

总结紧接上文章节,本章讲解Vuex,以及如何去修改state和mutations的使用。

1. 设置修改state的mutations事件在Vuex中,mutations是唯一修改state的方式。要设置一个mutations事件,首先需要在store中定义这个mutation,然后在组件中通过提交这个mutation来修改state。

javascript// store.jsconst store=new Vuex.Store({ state: { count: 0 }, mutations: { increment(state) { state.count++; } }});

export default store;

2. 提交mutations事件(常用的两种方法)在组件中,可以通过两种方式提交mutations事件:

- 直接调用mutation- 使用mapMutations辅助函数

直接调用mutation:

javascript// 在组件中methods: { increment() { this.$store.commit('increment'); }}

使用mapMutations辅助函数:

javascript// 在组件中import { mapMutations } from 'vuex';

export default { methods: { ...mapMutations(['increment']), increment() { this.increment(); } }}

总结以上是Vuex中设置和提交mutations事件的简单介绍。在项目中,我们可以根据需要定义多个mutations来管理state的状态变化。

目录
  • 1. 设置改变state的mutations事件
  • 2.提交mutations事件(常用的两种方法)
  • 总结

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

1. 设置改变state的mutations事件

index.js

dict.js

2.提交mutations事件(常用的两种方法)

<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 { mapMutations } from "vuex"; //修改vuex state第二种方式,首先引入 export default { data() { return {}; }, methods: { // 修改方式1,提交mutations changeUserInfo() { let userInfo = { name: "uzi", age: 24 }; //setUserInfo方法为你在vuex index.js 下的mutations下的注册的方法名称 this.$store.commit("setUserInfo", userInfo); }, // 修改方式2 ...mapMutations(["setUserInfo"]), //把vuex index.js 下的mutations下的注册的方法名称写入 changeUserInfo2() { let userInfo = { name: "kobe", age: 30 }; this.setUserInfo(userInfo); }, // ------------------------------------------------------------------ changeDict() { let dict = "进行中"; // 因为我们在modules下开启了命名空间,所以我们在调用dict下的Mutations时,需在前方加上空间名字 this.$store.commit("dict/setTaskTypeDict", dict); }, ...mapMutations({ setDict: "dict/setTaskTypeDict" }), //因为我们开辟了命名空间,故需要重写一个方法名,进行承接映射,注意此处不再是数组,而是一个对象 changeDict2() { let dict = "已完成"; this.setDict(dict); }, }, }; </script>

注释本人认为已写清

如何高效运用Vuex的mutations进行复杂state的改变?

总结

到此这篇关于vuex新手进阶篇之改变state mutations使用的文章就介绍到这了,更多相关vuex改变state mutations的使用内容请搜索自由互联以前的文章或继续浏览下面的相关文章希望大家以后多多支持自由互联!

本文共计686个文字,预计阅读时间需要3分钟。

如何高效运用Vuex的mutations进行复杂state的改变?

目录

1.设置修改state的mutations事件

2.提交mutations事件(常用的两种方法)

总结紧接上文章节,本章讲解Vuex,以及如何去修改state和mutations的使用。

1. 设置修改state的mutations事件在Vuex中,mutations是唯一修改state的方式。要设置一个mutations事件,首先需要在store中定义这个mutation,然后在组件中通过提交这个mutation来修改state。

javascript// store.jsconst store=new Vuex.Store({ state: { count: 0 }, mutations: { increment(state) { state.count++; } }});

export default store;

2. 提交mutations事件(常用的两种方法)在组件中,可以通过两种方式提交mutations事件:

- 直接调用mutation- 使用mapMutations辅助函数

直接调用mutation:

javascript// 在组件中methods: { increment() { this.$store.commit('increment'); }}

使用mapMutations辅助函数:

javascript// 在组件中import { mapMutations } from 'vuex';

export default { methods: { ...mapMutations(['increment']), increment() { this.increment(); } }}

总结以上是Vuex中设置和提交mutations事件的简单介绍。在项目中,我们可以根据需要定义多个mutations来管理state的状态变化。

目录
  • 1. 设置改变state的mutations事件
  • 2.提交mutations事件(常用的两种方法)
  • 总结

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

1. 设置改变state的mutations事件

index.js

dict.js

2.提交mutations事件(常用的两种方法)

<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 { mapMutations } from "vuex"; //修改vuex state第二种方式,首先引入 export default { data() { return {}; }, methods: { // 修改方式1,提交mutations changeUserInfo() { let userInfo = { name: "uzi", age: 24 }; //setUserInfo方法为你在vuex index.js 下的mutations下的注册的方法名称 this.$store.commit("setUserInfo", userInfo); }, // 修改方式2 ...mapMutations(["setUserInfo"]), //把vuex index.js 下的mutations下的注册的方法名称写入 changeUserInfo2() { let userInfo = { name: "kobe", age: 30 }; this.setUserInfo(userInfo); }, // ------------------------------------------------------------------ changeDict() { let dict = "进行中"; // 因为我们在modules下开启了命名空间,所以我们在调用dict下的Mutations时,需在前方加上空间名字 this.$store.commit("dict/setTaskTypeDict", dict); }, ...mapMutations({ setDict: "dict/setTaskTypeDict" }), //因为我们开辟了命名空间,故需要重写一个方法名,进行承接映射,注意此处不再是数组,而是一个对象 changeDict2() { let dict = "已完成"; this.setDict(dict); }, }, }; </script>

注释本人认为已写清

如何高效运用Vuex的mutations进行复杂state的改变?

总结

到此这篇关于vuex新手进阶篇之改变state mutations使用的文章就介绍到这了,更多相关vuex改变state mutations的使用内容请搜索自由互联以前的文章或继续浏览下面的相关文章希望大家以后多多支持自由互联!