vuex模块化中的命名空间

一.注意事项

默认情况下,子模块内部的 action、mutation 和 getter 是注册在全局命名空间的——可以直接通过全局的方式调用,如下是可以不带模块名直接调用方法修改的

  modules: {
    user: {
      state: {
        token: '12345'
      },
      mutations: {
        updateToken (state) {
          state.token = '678910'
        }
      }
    },
  }
<button @click="updateToken">点击修改user中的token</button>
import { mapMutations} from "vuex";
 methods:{
 ...mapMutations(["updateToken"]),
}

二.采用namespaced保证内部模块的高封闭性
总结:namespaced:true

  modules: {
    user: {
      namespaced:true,
      state: {
        token: '12345'
      },
      mutations: {
        updateToken (state) {
          state.token = '678910'
        }
      }
    },
  }

三.调用命名空间的方法

方法1:直接调用-带上模块的属性名路径
总结:this.$store.commit("模块名/mutations中的方法名")

<button @click="testFn">原始方式调用mutations方法-修改token</button>
methods:{
testFn(){
      this.$store.commit("user/updateToken")
    },
}

 

方法2:辅助函数-带上模块的属性名路径
总结:...mapMutations(['模块名/mutations中的方法名'])

<button @click="testFn1">mapMutations方法-修改user中的token</button>
import {mapMutations} from "vuex";
methods: {
       ...mapMutations(['user/updateToken']),
       testFn1 () {
           this['user/updateToken']()
       }
   }

 

方法3:createNamespacedHelpers 创建基于某个命名空间辅助函数
总结:
步骤1.import { createNamespacedHelpers} from "vuex";
步骤2.const { mapMutations } = createNamespacedHelpers('子模块名')
步骤3.methods:{
...mapMutations(["子模块中mutations里的方法"])
}

<button @click="updateToken">createNamespacedHelpers方法-修改user中的token</button>
import { createNamespacedHelpers} from "vuex";
const { mapMutations } = createNamespacedHelpers('user')//user为子模块名
methods:{
...mapMutations(["updateToken"]),//updateToken为子模块中mutations里的方法
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值