uniapp中action与mutation的区别

本文讲述了在uniapp的Vuex框架中,mutation用于同步、直接修改状态,而action则用于处理异步操作后提交mutation。通过实例说明了它们在计数器应用中的使用场景和区别。

在 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:

 

### 关于 UniApp Storeboard 制作方法或教程 在 UniApp 中,Storeboard 的制作通常涉及状态管理工具 Vuex 和组件化开发。Vuex 是 Vue.js 的官方状态管理库,可以帮助开发者集中管理应用的状态。以下是一个简单的 Storeboard 制作示例,结合了 Vuex 和组件通信的使用。 #### 1. 创建 Vuex Store 首先,在项目中创建一个 Vuex Store 来管理全局状态。 ```javascript // store/index.js import Vue from 'vue'; import Vuex from 'vuex'; Vue.use(Vuex); export default new Vuex.Store({ state: { boardItems: [], // 存储 Storeboard 的数据 }, mutations: { ADD_ITEM(state, item) { state.boardItems.push(item); // 添加新项目到 Storeboard }, REMOVE_ITEM(state, index) { state.boardItems.splice(index, 1); // 移除指定索引的项目 }, }, actions: { addItem({ commit }, item) { commit('ADD_ITEM', item); // 调用 mutation 添加项目 }, removeItem({ commit }, index) { commit('REMOVE_ITEM', index); // 调用 mutation 移除项目 }, }, getters: { getBoardItems: (state) => state.boardItems, // 获取 Storeboard 数据 }, }); ``` #### 2. 在页面中使用 Storeboard 接下来,在页面中通过 Vuex 的 `mapState` 和 `mapActions` 方法来操作 Storeboard。 ```vue <template> <view class="storeboard"> <view v-for="(item, index) in boardItems" :key="index" class="item"> {{ item }} <button @click="removeItem(index)">删除</button> </view> <input v-model="newItem" placeholder="输入新项目" /> <button @click="addItem">添加</button> </view> </template> <script> import { mapState, mapActions } from 'vuex'; export default { data() { return { newItem: '', // 输入的新项目 }; }, computed: { ...mapState(['boardItems']), // 映射 state }, methods: { ...mapActions(['addItem', 'removeItem']), // 映射 actions addItem() { if (this.newItem.trim()) { this.addItem(this.newItem); // 调用 action 添加项目 this.newItem = ''; // 清空输入框 } }, }, }; </script> <style> .storeboard { padding: 20px; } .item { margin-bottom: 10px; } </style> ``` #### 3. 配置 Vuex Store 确保在 `main.js` 中引入并配置 Vuex Store。 ```javascript import Vue from 'vue'; import App from './App'; import store from './store'; // 引入 Vuex Store Vue.config.productionTip = false; new Vue({ store, // 注册 Vuex Store render: (h) => h(App), }).$mount('#app'); ``` #### 4. 使用 Color UI 提升界面美观度 如果需要提升 Storeboard 的界面美观度,可以结合 Color UI[^1] 进行样式优化。例如,将按钮替换为 Color UI 样式。 ```vue <view class="cu-btn bg-blue" @click="addItem">添加</view> <view class="cu-btn bg-red" @click="removeItem(index)">删除</view> ``` 同时,在 `style` 中引入 Color UI 样式文件。 ```css @import "/colorui/main.css"; @import "/colorui/icon.css"; ``` 以上代码展示了如何在 UniApp 中实现一个简单的 Storeboard,并结合 Vuex 和 Color UI 提升用户体验。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值