vuex之modules

modules

如果不拆分对应模块,那么未来store中的相关内容会变得臃肿。所以我们可以把不同的组件的数据拆分成不同的模块。

命名空间

建议给所有的模块都添加命名空间

namespaced: true

const store = new Vuex.Store({
  state: {},
  modules: {
    moduleName: {
      namespaced: true
    }
  }
})

添加命名空间后,我们的mutation和action都会变成 模块名/对应名字

setName —> moduleName/setName

当我们添加了命名空间后,mapState、mapMutations、mapActions的用法就会发生响应的改变

模块中的相关属性的操作

{
  ...mapState('模块名', ['模块中state的属性名']),
  ...mapMutations('模块名', ['模块中的mutation的名字']),
  ...mapActions('模块名', ['模块中的action的名字'])
}

action

分发actions的操作变成了this.$store.dispatch('moduleName/actionName')

action中进行commit操作

在action中及那行commit操作时,只能commit当前模块中的mutation,不需要添加模块名

如果我们需要去提交其他模块或者root中的mutation时,需要设置第三个参数{root: true}

commit('moduleName/mutation名字', payload, {root: true})

mutation

提交mutation的操作变成了this.$store.commit('moduleName/mutationName')

默认情况,mutation中只能去获取到当前模块中的属性。

vuexmodules是用来将store分割成模块的功能。每个模块都有自己的state、mutation、action和getter,并且可以嵌套子模块。\[2\]通过使用modules,可以将应用的状态进行模块化管理,使得代码更加清晰和可维护。在使用modules时,可以将根模块放在modules文件夹的外面,也可以放在里面,最后在index文件中进行整合。\[1\]在index.js文件中,可以通过import语句引入子模块,并在modules对象中进行注册。\[3\]每个子模块都可以有自己的状态参数、mutations、actions和getters,并且可以通过命名空间来进行区分。\[2\]通过使用modules,可以更好地组织和管理vuex的状态。 #### 引用[.reference_title] - *1* *3* [vue - vuex详细讲解和modules模块化的使用](https://blog.csdn.net/qq_43886365/article/details/126893817)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [vuex总结(六)——module](https://blog.csdn.net/weixin_47450807/article/details/123104614)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值