vuex actions用法
时间: 2023-10-12 20:20:56 浏览: 85
vuex actions传递多参数的处理方法
在 Vuex 中,actions 用于处理异步操作和提交 mutations。它们可以包含任意异步操作,例如从服务器获取数据、处理数据并更新 store 中的 state 数据。
actions 是一个对象,其中每个属性都是一个函数,该函数接收一个 context 对象和一个 payload 参数。context 对象包含了一些属性和方法,例如 commit、dispatch、state 等,可以用来访问 store 中的数据和方法。payload 参数是传递给 action 函数的数据。
下面是一个简单的 actions 示例:
```
const actions = {
fetchData({ commit }) {
axios.get('/api/data')
.then(response => {
commit('SET_DATA', response.data)
})
.catch(error => {
console.log(error)
})
}
}
```
上述代码中,我们定义了一个名为 fetchData 的 action 函数,它接收一个 context 对象,我们从中提取了 commit 方法。在 fetchData 函数内部,我们使用 axios 库发送异步请求获取数据,并在成功返回时通过 commit 方法提交一个名为 SET_DATA 的 mutation,将数据更新到 store 中。
在组件中,我们可以使用 dispatch 方法来调用 actions:
```
methods: {
fetchData() {
this.$store.dispatch('fetchData')
}
}
```
在上述示例中,我们使用 dispatch 方法调用了名为 fetchData 的 action。在 action 执行完成后,我们可以通过 mutations 更新 store 中的 state 数据,然后在组件中通过 getters 获取更新后的数据。
阅读全文