vuex中store的action和mutations用法
更新时间:2022年04月12日 11:40:37 作者:zb0002011
这篇文章主要介绍了vuex中store的action和mutations用法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
action和mutations (this.$store.dispatch和this.$store.commit)区别
都是调用vuex中的方法。一个异步一个同步
dispatch:含有异步操作,例如向后台提交数据,写法: this.$store.dispatch('action方法名',值)commit:同步操作,写法:this.$store.commit('mutations方法名',值)
action:
1、用于通过提交mutation改变数据
2、会默认将自身封装为一个Promise
3、可以包含任意的异步操作
mutations:
1、通过提交commit改变数据
2、只是一个单纯的函数
3、不要使用异步操作,异步操作会导致变量不能追踪。也就是说,用action中的函数调用mutations中的函数,进行异步操作state中的数据
用法
dispatch: 含有异步操作
存储:
this.$store.dispatch('initUserInfo',friend);取值:
this.$store.getters.userInfo;
commit:同步操作
存储:
this.$store.commit('initUserInfo',friend);取值:
this.$store.state.userInfo;
实例
1、login.vue

2、user.js

3、login.js

action和mutation分别用来处理什么?
action处理异步数据最终提交到数据库mutation用来同步数据做业务的处理 (vuex中store数据改变唯一的方法就是mutation)Action提交的是 mutation,而不是直接变更状态。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
解决vue打包报错Unexpected token: punc的问题
这篇文章主要介绍了解决vue打包报错Unexpected token: punc的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-10-10
Vue 3 中 vue-router 的 router.resolve () API详解
router.resolve() 就好比是一个精准的 “导航参谋”,当我们在 Vue 3 应用里需要明确某个路由地址对应的详细信息时,它就能派上用场,本文给大家介绍Vue 3 中 vue-router 的 router.resolve () API,感兴趣的朋友一起看看吧2025-04-04
vue如何通过image-conversion实现图片压缩详解
在Vue项目中上传大图片时,可以通过image-conversion库压缩至指定大小,这篇文章主要介绍了vue如何通过image-conversion实现图片压缩的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下2024-12-12


最新评论