vuex03Getter与mapGetters

简介: 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'
  })
  }


相关文章
|
2月前
|
存储 缓存 JavaScript
一文带你了解vuex和使用(2024年11月)
欢迎来到我的博客,我是自学前端两年半的大一学生,熟悉JavaScript与Vue,正向全栈发展。本篇介绍了Vuex,Vue.js的状态管理模式,包括其核心概念如state、getter、mutation、action及模块化使用,通过集中管理状态确保应用状态的可预测变化。文章详细解析了Vuex的工作原理,特别是与Vue的computed属性和响应式系统的集成,以及如何在实际项目中搭建和使用Vuex。如果你觉得有帮助,欢迎关注,我将持续更新更多技术文章。🎉🎉🎉
52 0
|
7月前
|
存储 JavaScript
|
7月前
|
存储 JavaScript 前端开发
11.Vuex
11.Vuex
35 0
|
8月前
|
存储 JavaScript 前端开发
vuex使用
vuex使用
|
8月前
|
存储 JavaScript API
vuex的使用
vuex的使用
36 0
|
8月前
|
存储 JavaScript
什么是vuex
什么是vuex
56 0
|
8月前
|
存储 JavaScript 安全
vuex总结
vuex总结
73 0
|
存储 JavaScript
关于Vuex的简单实际应用
关于Vuex的简单实际应用
关于Vuex的简单实际应用
|
JavaScript
侃侃VUEX实现
「这是我参与2022首次更文挑战的第17天,活动详情查看:2022首次更文挑战」
|
存储 缓存 资源调度
Vuex
Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式 + 库。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。
Vuex