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中只能去获取到当前模块中的属性。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值