uniapp中action与mutation的区别

news/2024/9/24 11:01:35/

在 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/news/1440959.html

相关文章

用C实现通讯录(详细讲解+源码)

前言 📚作者简介:爱编程的小马,正在学习C/C,Linux及MySQL.. 📚以后会将数据结构收录为一个系列,敬请期待 ● 本期内容会给大家带来通讯录的讲解,主要是利用结构体来实现通讯录,该通讯…

ITMS-90426: Invalid Swift Support

原文 Please correct the following issues and upload a new binary to App Store Connect. ITMS-90426: Invalid Swift Support - The SwiftSupport folder is missing. Rebuild your app using the current public (GM) version of Xcode and resubmit it. 解决方式 ITMS-…

FIR补偿滤波器——matlab的FDA实现

输入采样频率:192KHz 抽取倍数:2 通带截至频率:20KHz 通带衰减:0.1dB 阻带衰减:120dB 在更多选项那里,设置c为0.5,代表抽取倍数为1/c,p设置为4,代表级联阶数。FIR补偿…

机器学习:深入解析SVM的核心概念(问题与解答篇)【一、间隔与支持向量】

直接阅读原始论文可能有点难和复杂,所以导师直接推荐我阅读周志华的《西瓜书》!!然后仔细阅读其中的第六章:支持向量机 间隔与支持向量 问题一:什么叫法向量?为什么是叫法向量 在这个线性方程中&#xff…

Int4:Lucene 中的更多标量量化

作者:来自 Elastic Benjamin Trent, Thomas Veasey 在 Lucene 中引入 Int4 量化 在之前的博客中,我们全面介绍了 Lucene 中标量量化的实现。 我们还探索了两种具体的量化优化。 现在我们遇到了一个问题:int4 量化在 Lucene 中是如何工作的以…

阳光电源社招前程无忧智鼎题库及远程包过助攻需要重点考察什么?

阳光电源社招前程无忧智鼎题库及远程包过助攻需要重点考察什么? 结合长期服务大型国有企业校招工作的经验,我们总结出阳光电源社招笔试的典型模式:行政职业能力测试企业应知应会测试心理测评,综合考察候选人的政治素养、文化素养…

PaddleSeg数据集的准备

PaddleSeg数据集格式 1、数据集及图片名称和目录无中文或奇怪字符 2、所有图片一个文件夹,所有标注一个文件夹,利用txt文件索引(当然有需要也可以使用不同文件夹,自己处理这个txt索引文件即可) 3、图片jpg格式&#x…

Swift中TableView的编辑模式

Swift中TableView的编辑模式可以通过UITableView的属性isEditing来控制。 要将TableView设置为编辑模式,可以使用以下代码: tableView.isEditing true要退出编辑模式,可以使用以下代码: tableView.isEditing false当TableVie…