Vuex学习笔记(四)——getters

Vuex中的getter,可以认为是store的计算属性。就跟计算属性一样,getter的返回值会根据它的依赖被缓存起来,且只有当它的以来至发生了改变才会被重新计算。

我们来看一个例子:

// 先创建一个store
const store = new Vuex.Store({
    state: {
        todos: [
            { id: 1, text: '...', done: true },
            { id: 2, text: '...', done: false },
            { id: 3, text: '...', done: true },
            { id: 4, text: '...', done: true },
            { id: 5, text: '...', done: true },
            { id: 6, text: '...', done: false }
        ]
    },
    mutations: {
        increment (state) {
            state.count++
        }
    },
    /*
    	vuex允许我们在store中定义getter,这个可以认为是store的计算属性。
        getter的返回值会根据它的依赖被缓存起来,且只有当它的依赖值发生了改变才会被重新计算
        Getter接受state作为其第一个参数
        filter返回符合条件的新数组
    */
    getters: {
        doneTodos: state => {
            return state.todos.filter(todo => todo.done)
        },
        // Getter也可以接受其他getter作为第二个参数
        doneTodoCounts: (state, getters) => {
            return getters.doneTodos.length
        },
        // 也可以返回一个函数,来实现给getter传参。在对store里的数组查询时非常有用。
        getTodoById: (state) => (id) => {
            return state.todos.find(todo => todo.id === id);
        }
    }
})

// 创建一个Vue实例
const vm = new Vue({
    el: "#app",
    store,
    template: `
            <div>
            <div>{{ doneTodoCount }}</div>
            <p v-for="(item, index) of doneTodoGetter" :key="index">{{item.id}}</p>
            <p>{{ getTodo }}</p>
            </div>
	`,
    computed: {
        // 如果有多个组件需要用到此属性,我们要么复制这个函数,或者抽取到一个共享函数然后在多处导入它无论哪种方式都不是很理想。
        doneTodoCount() {
            // 获取集合中key值为done的长度
            // return this.$store.state.todos.filter(todo => todo.done).length
            return this.$store.getters.doneTodoCounts
        },

        // getter会暴露为store.getters对象,你可以以属性的形式访问这些值:
        // store.getters.doneTodos // -> [{ id: 1, text: '...', done: true }]
        doneTodoGetter() {
            return this.$store.getters.doneTodos
        },
        getTodo() {
            return this.$store.getters.getTodoById(2)
        }
    },
})

公众号:Coder 杂谈,欢迎关注
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值