vuex03Getter与mapGetters

Getter是个啥

是个对象,类似于computed里面的对象

如果我们需要对state对象进行做处理计算,比如说,我们有三家超市,我们想计算三家超市的总营业额。同时还要计算实际的收入,假设成本是200。
同时getter还可以接收其他其他getter

const store = new Vuex.Store({
    state: {
        shop1: 100,
        shop2: 200,
        shop3: 300,
    },
    getters: {
        getShopTotal(state) {
            return state.shop1 + state.shop2 + state.shop3
        },
        getShopMoney(state, getters) {
            return getters.getShopTotal - 200
        }
    }
})
 computed: {
    shopTotal() {
      return this.$store.getters.getShopTotal;
    },
    shopMoney() {
      return this.$store.getters.getShopMoney;
    }
  },

Getter传参

在上面的例子我们可以返现,getter里面其实就是一个属性,我们当然可以让这些属性来接收一个函数。
在上面,我们发现,想计算利润的话需要在里面减去200,如果不同的超市,都想调用这个getter的话,但是成本不是200的話,就需要写好多函数,所以我们考虑getter可以接受参数。

 getters: {
	 getShopMoney: function (state, getters) {
	            return (zhichu) => {
	                return getters.getShopTotal - 200 - zhichu
	            }
	  }
   }
computed: {
    shopMoney() {
      return this.$store.getters.getShopMoney(100);
    }
  },

mapGetters 辅助函数

mapGetters 辅助函数仅仅是将 store 中的 getter 映射到局部计算属性,

  1. 引入mapGetters
import { mapGetters } from 'vuex'

  1. 使用
computed: {
  // 使用对象展开运算符将 getter 混入 computed 对象中
    ...mapGetters([
      'getShopTotal',
      'getShopMoney',
    ]),
    或者
	    mapGetters({
	  // 把 `this.shopTotal` 映射为 `this.$store.getters.getShopTotal`
	  shopTotal: 'getShopTotal'
	})
  }
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

YOLO大王

你的打赏,我的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值