Vue中commit和dispatch区别及其用法辨析

在Vue中,commitdispatch是两个用于触发 Vuex store 中的 mutations 和 actions 的方法。

区别

  1. commit: 用于触发 mutations,即直接修改 state 的同步操作。通过commit方法可以调用 store 中的 mutations,并且只能同步地执行。使用方式如下:

    javascript 复制代码
    this.$store.commit('mutationName', payload);
  2. dispatch: 用于触发 actions,即执行异步操作或者复杂的逻辑处理。通过dispatch方法可以调用 store 中的 actions,并且可以是异步的。使用方式如下:

    javascript 复制代码
    this.$store.dispatch('actionName', payload);

辨析:

  • 当需要修改 state 时,应该使用**commit来调用 mutations**。
  • 当需要进行异步操作、例如发送网络请求、多个 mutations 之间有依赖关系等情况,应该使用**dispatch来调用 actions**。

总结

commit用于同步操作,主要用来修改 state;dispatch用于异步操作,主要用来执行一系列的操作,包括触发多个 mutations 或者其他一些异步操作。

异步操作:从云端拉取信息后才会执行,放在actions中

同步操作:放在mutations中

相关推荐
Highcharts.js13 分钟前
AI向量知识谱系图表创建示例代码|Highcharts网络图表(networkgraph)搭建案例
开发语言·前端·javascript·网络·信息可视化·编辑器·highcharts
阿正的梦工坊21 分钟前
React:构建用户界面的JavaScript库
javascript·react.js·ui
行走的陀螺仪29 分钟前
[特殊字符] JavaScript 设计模式完全指南:从入门到精通(含20种模式)
开发语言·javascript·设计模式
zhangxingchao30 分钟前
AI应用开发五:RAG高级技术与调优
前端·人工智能·后端
KaMeidebaby41 分钟前
卡梅德生物技术快报|单 B 细胞抗体技术:全犬源单抗制备流程、关键参数与性能验证
前端·数据库·其他·百度·新浪微博
hazel1 小时前
网络与工程化
前端
KnowWhere1 小时前
Vue3 调试技巧:一键挂载组件实例到 Window(仅开发环境生效)
vue.js
胡萝卜术1 小时前
《JavaScript 语言精粹》第三章精读:对象——最基础也最容易被误解的基石
javascript
甜味弥漫1 小时前
一篇文章搞懂CSS中的定位布局
前端
A南方故人1 小时前
vue3常用指令以及注册
前端·javascript·vue.js