uniapp中action与mutation的区别

devtools/2024/10/19 7:27:14/

在 uniapp 的 Vuex 状态管理库中,action 和 mutation 是两个非常重要的概念,它们各自有不同的职责和使用场景。虽然它们都是用来修改状态(state)的,但它们在使用的方式和执行的时机上存在一些关键的区别。

Mutation

直接修改状态:mutation 是直接修改 state 的唯一方式。每个 mutation 都有一个字符串的 type 和一个处理器函数。这个处理器函数会接收 state 作为第一个参数。

同步操作:mutation 必须是同步函数。这是因为 Vuex 需要在每个 mutation 执行后追踪状态的变化,从而触发相应的视图更新。如果 mutation 里有异步操作,Vuex 就无法追踪到状态的变化。

简单性:由于 mutation 必须是同步的,因此它们通常相对简单,主要用于直接修改状态。

Action

提交 mutation:action 类似于 mutation,但它是用来提交 mutation 的,而不是直接修改状态。你可以在 action 内部执行一些异步操作(例如 API 调用),然后在操作完成后提交一个 mutation 来修改状态。

异步操作:action 可以包含任意异步操作。这是它与 mutation 的主要区别。

灵活性:由于 action 可以包含异步操作,因此它们通常更加灵活,可以处理更复杂的逻辑和异步数据流。

使用场景

当你需要直接、同步地修改状态时,应该使用 mutation。

当你需要执行异步操作(如 API 调用)并在操作完成后修改状态时,应该使用 action。

总结

action 和 mutation 都是 Vuex 中用于修改状态的重要概念,但它们在使用的方式和执行的时机上有所不同。mutation 用于直接、同步地修改状态,而 action 则用于提交 mutation,并可以包含异步操作。理解并正确使用它们,可以帮助你更好地管理应用的状态。

在 uniapp 中,Vuex 是用于状态管理的库,它包含了 state、getters、mutations 和 actions 等概念。下面我将为你提供一个简单的 action 和 mutation 的例子来说明它们是如何工作的。

首先,假设我们有一个简单的计数器应用,我们需要通过 Vuex 来管理这个计数器的状态。

1. 定义 State

在 store.js 文件中,我们首先定义 state:

javascript

export default new Vuex.Store({

  state: {

    count: 0

  },

  // ... 其他选项

});

 

2. 定义 Mutation

接下来,我们定义一个 mutation 来修改 count 的值:

javascript

export default new Vuex.Store({

  state: {

    count: 0

  },

  mutations: {

    INCREMENT(state) {

      state.count++;

    }

  },

  // ... 其他选项

});

在这个例子中,我们定义了一个名为 INCREMENT 的 mutation,它会将 count 的值增加 1。

3. 定义 Action

然后,我们定义一个 action 来处理异步操作,并在操作完成后提交 mutation:

javascript

export default new Vuex.Store({

  state: {

    count: 0

  },

  mutations: {

    INCREMENT(state) {

      state.count++;

    }

  },

  actions: {

    async incrementAsync({ commit }) {

      // 假设这里有一个异步操作,比如 API 调用

      await new Promise(resolve => setTimeout(resolve, 1000)); // 模拟异步操作,延迟1秒

      commit('INCREMENT'); // 异步操作完成后,提交 mutation 修改状态

    }

  },

  // ... 其他选项

});

在这个例子中,我们定义了一个名为 incrementAsync 的 action。这个 action 在内部执行了一个模拟的异步操作(使用 setTimeout 来模拟 API 调用的延迟),然后在异步操作完成后,通过 commit 方法提交了 INCREMENT 这个 mutation 来修改 count 的值。

4. 在组件中使用 Action

最后,在组件中,我们可以通过 this.$store.dispatch 来调用 action:

 


http://www.ppmy.cn/devtools/20676.html

相关文章

设计模式(八):桥接模式

设计模式(八):桥接模式 1. 桥接模式的介绍2. 桥接模式的类图3. 桥接模式的实现3.1 创建实现接口3.2 创建实现了 Cook 接口的实体桥接实现类3.3 使用 Cook 接口创建抽象类 Chef3.4 创建实现了 Chef 抽象类的实体类3.5 测试 1. 桥接模式的介绍 …

【随想录】Day35—第八章 贪心算法 part04

目录 题目1: 柠檬水找零1- 思路2- 题解⭐ 柠檬水找零 ——题解思路 题目2: 406. 根据身高重建队列1- 思路2- 题解⭐ 根据身高重建队列 ——题解思路 题目3: 用最少数量的箭引爆气球1- 思路2- 题解⭐ 用最少数量的箭引爆气球 ——题解思路 题目1: 柠檬水找零 题目链接&#xff…

基于单片机公交语音报站系统设计 含源码,Proteus仿真原理图

资料下载地址:基于单片机公交语音报站系统设计 含源码,Proteus仿真原理图 1、前言 系统的总体设计需要充分运用STC单片机作为主控控制芯片,完成主控控制电路的基本设计,辅助控制电路是语音控制电路、12864显示电路、按键控制电路、…

Pytorch 的实际应用 学习笔记

一. 模型的下载 weights为false时则为没有提前经过训练的模型,为true时则经过了提前训练 vgg16_false torchvision.models.vgg16(weightsFalse) vgg16_true torchvision.models.vgg16(weightsTrue) 打印 二. 模型的修改 (1)添加操作 …

RAG开山之作:结合参数化与非参数化记忆的知识密集型NLP任务新解法

20年RAG刚提出时的论文:Retrieval-Augmented Generation for Knowledge-Intensive NLP Tasks,也算是RAG的开山之作之一了。 摘要:检索增强生成(RAG)方法结合了预训练语言模型与基于检索的非参数化记忆,通过…

Flink 实时数仓(二)【ODS 层开发】

前言 最近投了不少的实习,也收到不错的反馈,虽然是中小公司偏多,但是毕竟现在这个环境双非进大厂实习可不同当年了。可惜的是学院不放人,无奈啊,遍身罗绮者,不是养蚕人。我累死累活肝了两年了,好…

cnpm安装

npm install -g cnpm --registryhttps://registry.npmmirror.com # 注册模块镜像 npm set registry https://registry.npmmirror.com // node-gyp 编译依赖的 node 源码镜像 npm set disturl https://npmmirror.com/dist // 清空缓存 npm cache clean --force // 安装c…

基于YOLOV8+Pyqt5无人机航拍太阳能电池板检测系统

1.YOLOv8的基本原理 YOLOv8是一种前沿的目标检测技术,它基于先前YOLO版本在目标检测任务上的成功,进一步提升了性能和灵活性,在精度和速度方面都具有尖端性能。在之前YOLO 版本的基础上,YOLOv8 引入了新的功能和优化,…