Vuex子模块调用子模块的actions或mutations实现方式

 更新时间:2023年10月27日 08:41:37   作者:Gik99  
这篇文章主要介绍了Vuex子模块调用子模块的actions或mutations实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

Vuex子模块调用子模块的actions或mutations

项目场景

Vuex中子模块如何调用子模块的actions或mutations

问题描述

因为有的子模块开启了命名空间,其他子模块不能直接访问

如果子模块没有开启命名空间,默认mutations和actions是挂载到全局上 都可以直接调用

这是准备调用的子模块代码 permission.js

const state = {}
const mutations = {}
const actions = {}
}
export default {
  namespaced: true, // 开启命名空间
  state,
  mutations,
  actions
}

解决方案

使用 {root:true}

调用的子模块的代码

const actions = {
  async lgout(context) {
    // 调用 permission 另一子模块下的方法
    context.commit('permission/setRoutes', [], { root: true })
  }
}

vuex中actions和mutations区别

定义:

在Vuex中,actions和mutations是两个核心概念,用于管理应用程序状态的变化。

Mutations

mutations是用于修改Vuex状态的唯一方法。

它们是同步操作,意味着它们必须是纯函数,以确保状态的可预测性。

这意味着mutations应该只用于同步操作,例如在响应用户事件时更新状态。

它们不应该包含任何异步代码,如API调用。

举个例子,下面的代码演示了如何定义一个名为increment的mutation,用于将state中的count属性增加

const store = new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    increment(state) {
      state.count++
    }
  }
})

store.commit('increment') // 调用mutation

Actions

actions用于执行异步操作或包含异步操作的操作序列。

它们可以包含任何异步代码,例如API调用或其他异步操作,但不能直接修改状态。

相反,它们通过commit触发mutations来间接修改状态。

举个例子,下面的代码演示了如何定义一个名为fetchData的action,它会异步获取数据并提交mutation来更新状态:

const store = new Vuex.Store({
  state: {
    data: null
  },
  mutations: {
    setData(state, data) {
      state.data = data
    }
  },
  actions: {
    async fetchData({ commit }) {
      const response = await fetch('https://api.example.com/data')
      const data = await response.json()
      commit('setData', data)
    }
  }
})

store.dispatch('fetchData') // 调用action

总之,mutations和actions有不同的角色和职责。

mutations用于同步状态的修改,actions用于执行异步操作并间接修改状态。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 浅谈Vue页面级缓存解决方案feb-alive (下)

    浅谈Vue页面级缓存解决方案feb-alive (下)

    这篇文章主要介绍了浅谈Vue页面级缓存解决方案feb-alive(下),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • vuejs如何配置less

    vuejs如何配置less

    本篇文章主要介绍了vuejs如何配置less,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • 解决vue app.js/vender.js过大优化启动页

    解决vue app.js/vender.js过大优化启动页

    这篇文章主要为大家介绍了解决vue app.js/vender.js过大优化启动页过程详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • Vue使用mixins实现压缩图片代码

    Vue使用mixins实现压缩图片代码

    本篇文章主要介绍了Vue使用mixins实现压缩图片代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • Vue 子组件使用 this.$parent 无法访问到父组件数据和方法(解决思路)

    Vue 子组件使用 this.$parent 无法访问到父组件数据和方法(解决思路)

    这篇文章主要介绍了Vue 子组件使用 this.$parent 无法访问到父组件数据和方法,解决思路也很简单,本文结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • vue中iframe使用以及结合postMessage实现跨域通信

    vue中iframe使用以及结合postMessage实现跨域通信

    这篇文章主要介绍了vue中iframe使用以及结合postMessage实现跨域通信方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • vue+element表格导出为Excel文件

    vue+element表格导出为Excel文件

    这篇文章主要为大家详细介绍了vue+element表格导出为Excel文件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-09-09
  • Vue应用中使用xlsx库实现Excel文件导出的详细步骤

    Vue应用中使用xlsx库实现Excel文件导出的详细步骤

    本文详细介绍了如何在Vue应用中使用xlsx库来导出Excel文件,包括安装xlsx库、准备数据、创建导出方法、触发导出操作和自定义Excel文件等步骤,xlsx库提供了强大的API和灵活的自定义选项,使得处理Excel文件变得简单而高效
    2024-10-10
  • Vue3组件间传值避坑方法指南

    Vue3组件间传值避坑方法指南

    这篇文章主要为大家介绍了Vue3组件间传值避坑方法指南,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • vue2.0 keep-alive最佳实践

    vue2.0 keep-alive最佳实践

    这篇文章主要为大家详细介绍了vue2.0 keep-alive的最佳实践,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07

最新评论