vuex_Getter_03

2019-12-17  本文已影响0人  soulisfree

Getter

有时候我们需要从 store 中的 state 中派生出一些状态,比如获取姓名的时候要将姓名翻转

<h2>{{msg}}</h2>
<p>{{name}}</p>

computed: mapState({
    name(state) {
        return state.name.split('').reverse().join('')
    }
})
getter01.png

如果有多个组件需要用到此属性,我们要么复制这个函数,或者抽取到一个共享函数然后在多处导入它——无论哪种方式都不是很理想

Vuex 允许我们在 store 中定义“getter”(可以认为是 store 的计算属性)。就像计算属性一样,getter 的返回值会根据它的依赖被缓存起来,且只有当它的依赖值发生了改变才会被重新计算

Getter 接受 state 作为其第一个参数
store/index.js

const state = {
    count: 1,
    sex: '男',
    name: 'qzy',
    age: 18
}
const getters = {
    name: state => state.name.split('').reverse().join('')
}

export default new Vuex.Store({
    state,
    getters
})

About.vue

<h2>{{msg}}</h2>
<p>{{name}}</p>

computed: {
    name(){
        return this.$store.getters.name
    }
}

显示结果与原来一致

Getter 会暴露为 store.getters 对象,可以以属性的形式访问这些值

Getter 也可以接受其他 getter 作为第二个参数
const getters = {
    name: state => state.name.split('').reverse().join(''),
    userInfo: ((state, getter) => {
        return `用户姓名为${getter.name},年龄为${state.age}`
    })
}

About.vue

<p>{{name}}</p>
<p>{{userInfo}}</p>

computed: {
    name() {
        return this.$store.getters.name
    },
    userInfo() {
        return this.$store.getters.userInfo
    }
}
getter02.png

这样我们可以很容易地在任何组件中使用它。

注意,getter 在通过属性访问时是作为 Vue 的响应式系统的一部分缓存其中的

通过方法访问

你也可以通过让 getter 返回一个函数,来实现给 getter 传参。在你对 store 里的数组进行查询时非常有用

const state = {
    // ...
    arr: [{
        id: 1,
        text: 1
    }, {
        id: 2,
        text: 2
    }]
}

const getters = {
    // ...
    getArrById: ((state) => {
        return(id) => {
            return state.arr.find(item => item.id === id)
        }
    })
}

<p>{{getArrById(1)}}</p>

computed: {
    // ...
    getArrById() {
        return this.$store.getters.getArrById
    }
}
getter03.png

注意,getter 在通过方法访问时,每次都会去进行调用,而不会缓存结果

mapGetters 辅助函数

作用与使用方法基本与mapState保持一致

import {mapGetters} from 'vuex'

computed: {
    ...mapGetters(['name','userInfo','getArrById'])
}
上一篇 下一篇

猜你喜欢

热点阅读