vuex分模块后,实现获取state的值
问题:vuex分模块后,一个模块如何拿到其他模块的state值,调其他模块的方法?
思路:
1.通过命名空间取值--this.$store.state.car.list//OK
2.通过定义该属性的getter方法,因方法全局注册,不存在命名空间,可以通过this直接调用。
this.$store.state.car.carGetter
我在car模块中自己的定义了state,getters,
this.$store.state.car.list可以拿到值.
但是,this.$store.state.car.carGetter报错,
请问.如何在组件中调用这个getters,
//car.js state={ list:[] } getters={ carGetter:state=>{ returnstate.list.filter(''); } } newVuex.Store({ getters:{ test:state=>{ return'02'; } }, modules:{car} }) //组件 this.$store.state.car.list//OK this.$store.state.car.carGetter//undefined this.$store.state.carGetter//为什么这么用ok,难道会把模块中的getters注册到root?
已解决!
模块内部的action、mutation、和getter现在仍然注册在全局命名空间——这样保证了多个模块能够响应同一mutation或action。
补充知识:vuex使用模块的时候获取state里的数据语法
普通语法
this.$store.state.【哪个数据】
模块化语法:
this.$store.state.【哪个模块】.【哪个数据】
购物车列表