时间:2021-05-26
问题: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.jsstate = { list: []}getters = { carGetter: state => { return state.list.filter(''); }}new Vuex.Store({ getters: { test: state => { return '02'; } }, modules: { car } })// 组件this.$store.state.car.list // OKthis.$store.state.car.carGetter // undefinedthis.$store.state.carGetter // 为什么这么用ok, 难道会把模块中的getters注册到root ?已解决!
模块内部的 action、mutation、和 getter 现在仍然注册在全局命名空间——这样保证了多个模块能够响应同一 mutation 或 action。
补充知识:vuex使用模块的时候 获取state里的数据语法
普通语法
this.$store.state.【哪个数据】
模块化语法:
this.$store.state.【哪个模块】.【哪个数据】
<template><div class="panel panel-info"> <div class="panel-heading"> <h4 class="panel-title">购物车列表</h4> </div> <div class="panel-body"> <p v-if="!CartList.length">这里什么都没有,请先添加商品。</p> <CartListItem v-for="ele in CartList" :key="ele.id" :cartlist-iteam="ele"/> </div> <div class="panel-footer"> <a href="" class="btn btn-block btn-danger">清空购物车({{cartQuantity}})</a> <a href="" class="btn btn-block btn-info">立即结算({{cartTotal}})</a> </div> </div></template><script>import CartListItem from './CartListItem'import { mapGetters } from 'vuex'export default { name: 'CartList', components: { CartListItem }, computed: { CartList () { return this.$store.state.cartModule.updateCartList }, ...mapGetters(['cartQuantity', 'cartTotal']) }}</script>以上这篇vuex分模块后,实现获取state的值就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
vue在做大型项目时,会用到多状态管理,vuex允许我们将store分割成多个模块,每个模块内都有自己的state、mutation、action、getter
一、介绍vuex里面的四大金刚:State,Mutations,Actions,Getters(上次记得关于vuex笔记https://mit,改变state的
一、使用Vuex的目的实现多组件状态管理。多个组件之间需要数据共享时,Vuex是个很好的帮手哦二、Vuex的五大核心其中state和mutation是必须的,其
VUEX数据持久化//store.jsgetters:{userInfo(state){console.log('getters',state);if(!sta
main.js中importVuexfrom'vuex'Vue.use(vuex);conststore=newVuex.store({ state:{