vuex中getters

vuex中的getters类似于计算属性computed,对数据池state中的值进行处理

(1)在组件中将值添加到state的personList属性中

<template>
<div>
  <input type="text" v-model="addValue">
  <button @click="add">添加</button>
  <ul>
    <li v-for="(item,index) in newPerson" :key="index">{{index}}:{{item}}</li>
  </ul>
</div>

</template>


    data () {
      return {
        addValue: '',
      }
    },
    computed: {
      ...mapState({
        personList: state => state.personList,
      }),
      //上面的可以简写:
      //...mapState(['personList'])
      newPerson () {
       
        return this.$store.getters.newPerson
      }
    },
    methods: {
      add () {

         console.log(this.$store.getters.newPerson)
        if(this.addValue == ''){
          return
        }
        console.log(this.addValue);
        this.$store.state.personList.push(this.addValue)
        this.addValue = ''
      }
    },

(2)在vuex的getters中对personList的值进行处理,赋给newPerson

  state: {
    login: false,
    name: 'zhu',
    age: 23,
    personList: [],
  },
  getters: {
    newPerson (state) {
      return state.personList.map((item, index) => {
        if(index == 0) {
          return '@@@@' + item
        }else if(index < 3) {
          return '###' + item + '$$$'
        }else {
          return '++' + item + '***'
        }
      })
    }
  },

(3)在组件中通过计算属性computed,来获取newPerson

(4)在标签中v-for对newPerson数组进行遍历

2. mapGetters

mapGetters和mapState用法一样

(1)引入:import { mapState, mapGetters } from 'vuex'

(2)在组件的computed中使用:

    computed: {
      ...mapState({
        personList: state => state.personList,
      }),
      //上面的可以简写:
      //...mapState(['personList'])
      ...mapGetters (['newPerson'])
      // newPerson () {
      //   return this.$store.getters.newPerson
      // }
    },

3. getters中的函数中还有第二个参数“getters”,就是getters本身,它可以调用getters中的其他函数。

  getters: {
    newPerson (state, getters) {
      return state.personList.map((item, index) => {
        if(index == 0) {
          return '@@@@' + item + getters.a
        }else if(index < 3) {
          return '###' + item + '$$$'+ getters.a
        }else {
          return '++' + item + '***'+ getters.a
        }
      })
    },
    a () {
      return '1111'
    }
  },

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值