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通过NGINX部署在子目录或者二级目录实践

    详解vue通过NGINX部署在子目录或者二级目录实践

    这篇文章主要介绍了详解vue通过NGINX部署在子目录或者二级目录实践,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • Vuex如何获取getter对象中的值(包括module中的getter)

    Vuex如何获取getter对象中的值(包括module中的getter)

    这篇文章主要介绍了Vuex如何获取getter对象中的值(包括module中的getter),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • vue顶部菜单栏实现小结

    vue顶部菜单栏实现小结

    这篇文章主要介绍了vue顶部菜单栏实现小结,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • Vue项目自动转换 px 为 rem的实现方法

    Vue项目自动转换 px 为 rem的实现方法

    这篇文章主要介绍了Vue项目自动转换 px 为 rem的实现方法,本文是通过一系列的配置后,转换成热门,具体内容详情大家跟随小编一起通过本文学习吧
    2018-10-10
  • axios封装与传参示例详解

    axios封装与传参示例详解

    这篇文章主要给大家介绍了关于axios封装与传参的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • elementUI checkBox报错Cannot read property 'length' of undefined解决

    elementUI checkBox报错Cannot read property &ap

    这篇文章主要为大家介绍了elementUI checkBox报错Cannot read property 'length' of undefined的解决分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • vue实现简易计算器功能

    vue实现简易计算器功能

    这篇文章主要为大家详细介绍了vue实现简易计算器功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-01-01
  • Vue数字相加、相减精度丢失处理3种方法

    Vue数字相加、相减精度丢失处理3种方法

    这篇文章主要给大家介绍了关于Vue数字相加、相减精度丢失处理3种方法的相关资料,前端在操作加减乘除计算时,经常会出现精度缺失问题,有时会显示为科学计数的样式,需要的朋友可以参考下
    2023-08-08
  • vue使用splice()删除数组中的一个数据 弹出窗口提示问题

    vue使用splice()删除数组中的一个数据 弹出窗口提示问题

    这篇文章主要介绍了vue使用splice()删除数组中的一个数据 弹出窗口提示问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • vant之van-list的使用及踩坑记录

    vant之van-list的使用及踩坑记录

    这篇文章主要介绍了vant之van-list的使用及踩坑记录,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04

最新评论