mapState,模块化,命名空间

mapState是一个语法糖,原来写法为

shuju(){

return this.$store.state.shuju;

}

mapState不用写的那么麻烦,computed:mapState({shuju:‘shuju’})

如果有自己的计算属性的话,要用扩展运算符,注意此时computed后面有大括号{}

则computed:{

zishen(){

return this.s+1

}

...mapState(['shuju'])

}

基本形式:

借助mapState生产计算属性,从state中读取数据,

对象写法

...mapState({he:'sum',xuexaio:'school',xueke:'subject'])

数组写法

...mapState(['sum','school','subject']),

从state中直接读取数据this.$store.state.shuju

this.$store.commit('fangfa',canshu)

this.$store.getters.shuju

模块化后:

mapState(['mokuai1','mokuai2'])读取数据时用this.state.mokuai1.shuju

或者想要直接读取模块里的数据就以下面这种命名空间形式。

mapState('mokuai1',['sum','school']),

mapgetters('mokuai1',['sum','school']),注意这样的是开启命名空间

第一个参数指定用哪一个模块,直接用不可以,必须使用namespace:true命名空间,才能使用

也可以不用命名空间,mapState({shuju:state=>state.mokuai1.shuju})注意这不是开启命名空间

从state中直接读取数据this.$store.state.mokuai1.shuju

this.$store.commit('mokuai1/fangfa',canshu)

this.$store.getters['mokuai1/shuju']注意这样的也是开启命名空间的getters只有mokuai1/shuju这个属性,且用.加属性这里不行,所以只能用[]加属性。如果用mapGetters的话和用其他的mapState一样。

getters没有划分模块,命名空间时会划分

​​​​​Vuex文档

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值