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
    评论
`map`是Vuex提供的一个辅助函数,用于将store的state、getters、mutations、actions等映射到组件的computed、methods等。 当我们在一个大型的项目使用Vuex时,通常会将store分割成多个模块,每个模块负责管理一个特定的领域状态。为了避免不同模块之间的命名冲突,Vuex提供了命名空间(namespace)的概念。 命名空间可以通过在模块添加`namespaced:true`来启用,这样就可以在组件使用`mapState`、`mapGetters`、`mapMutations`、`mapActions`时指定模块的命名空间,例如: ```javascript // store/moduleA.js const moduleA = { namespaced: true, state: { ... }, getters: { ... }, mutations: { ... }, actions: { ... } } // 组件使用mapState import { mapState } from 'vuex' export default { computed: { ...mapState('moduleA', { a: state => state.a, b: state => state.b }) } } // 组件使用mapGetters import { mapGetters } from 'vuex' export default { computed: { ...mapGetters('moduleA', { c: 'getC', d: 'getD' }) } } // 组件使用mapMutations import { mapMutations } from 'vuex' export default { methods: { ...mapMutations('moduleA', { setA: 'setA', setB: 'setB' }) } } // 组件使用mapActions import { mapActions } from 'vuex' export default { methods: { ...mapActions('moduleA', { doActionA: 'doActionA', doActionB: 'doActionB' }) } } ``` 使用命名空间可以有效地管理模块的状态,避免了命名冲突。但是在使用`map`函数时,需要注意指定模块的命名空间,否则会出现无法正确获取模块内的状态和方法的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值