vuex中getters的基本用法解读
getters的基本用法解读
一、getter 定义
Vuex允许我们在store中定义"getter" ,用于对state中存储的数据进行过滤操作。
就像vue生命周期中的computed一样,getter的返回值 会根据它的依赖被缓存起来,且只有当它的依赖值发生了改变才会被重新计算
二、使用方法
1、通过属性访问
Getter 接受 state 作为其第一个参数:
example:现在需要获取list:[1,2,3,4,5,6,7,8,9]中大于5的元素
const store = new Vuex.Store({ state:{ list: [1,2,3,4,5,6,7,8,9] } , getters: { getNumber: state => { retrun state.list.filter(item => item > 5) } } })
在.vue中使用
computed:{ getNumber(){ return this.$store.getters.getNumber } }
2、通过方法访问
同样的数组list 需要根据不同的条件返回不同的数据
通过让 getter 返回一个函数,来实现给 getter 传参
const store = new Vuex.Store({ state:{ list: [1,2,3,4,5,6,7,8,9] } , getters: { getNumber: state => (index) => { return state.list.filter(item => item > index) } } })
在.vue中使用
computed:{ getNumber(){ return this.$store.getters.getNumber(4) } }
3、依赖于已存在的getters
example: 获取list中大于5的数字的个数
注意:如果getters返回的是一个方法,不能用这种方式
const store = new Vuex.Store({ state:{ list: [1,2,3,4,5,6,7,8,9] } , getters: { getNumber: state => { return state.list.filter(item => item > 6) }, getNumberLength: (state, getters) = > { return getters.getNumber.length } } })
三、mapGetters辅助函数
mapGetters 辅助函数仅仅是将 store 中的 getter 映射到局部计算属性:
import { mapGetters } from 'vuex' export default { // ... computed: { // 使用对象展开运算符将 getter 混入 computed 对象中 ...mapGetters([ 'doneTodosCount', 'anotherGetter', // ... ]) } }
如果你想将一个 getter 属性另取一个名字,使用对象形式:
import { mapGetters } from 'vuex' export default { // ... computed: { ...mapGetters({ // 把 `this.doneCount` 映射为 `this.$store.getters.doneTodosCount` doneCount: 'doneTodosCount' }) } }
四、getters注意事项
1、data中定义的属性名称不能和computed中定义的getter名称相同,否则会报错
2、vuex中state和getter中可以定义同名属性,互不干扰
getters的两种调用方法
getters和state用法相似,有点像vue中里面的data 和computed两个之间的关系
使用:
state: { count:0, }, getters:{ countAdd(state){ return state.count + 1 } },
方法一
this.$store.getters.xxx
xxx是getters里面的名称
方法二
import { mapGetters } from 'vuex' ..... computed:{ ...mapGetters(['countAdd']) }
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Vuejs入门教程之Vue生命周期,数据,手动挂载,指令,过滤器
本篇文章主要介绍了Vuejs入门教程之Vue生命周期,数据,手动挂载,指令,过滤器的相关知识。具有很好的参考价值。下面跟着小编一起来看下吧2017-04-04vue3+ts数组去重方及reactive/ref响应式显示流程分析
这篇文章主要介绍了vue3+ts数组去重方法-reactive/ref响应式显示,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-04-04Vue ElementUI table实现双击修改编辑某个内容的方法
在实现表格单元格双击编辑功能时,需使用@cell-dblclick事件来触发双击操作,将单元格切换为input输入框,通过ref引用和绑定失焦及回车事件来确认编辑,同时,需要处理编辑数据的更新和方法逻辑的完善2024-09-09
最新评论