Vuex如何获取getter对象中的值(包括module中的getter)

 更新时间:2022年08月31日 11:29:42   作者:trenki  
这篇文章主要介绍了Vuex如何获取getter对象中的值(包括module中的getter),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

Vuex获取getter对象中的值

getter取值与state取值具有相似性

1.直接从根实例获取

// main.js中,把store注册在根实例下,可使用this.$stroe.getters直接取值
computed: {
  testNum1() {
    return this.$store.getters.testNum1;
  }
}

2.使用mapGetters取值

import { mapGetters } from "vuex";
export default {
  computed: {
    ...mapGetters({
      // 把 `this.getNum1` 映射为 `this.$store.getters.getNum1`
      getNum1: "getNum1"
    }),
    ...mapGetters([
      // 使用对象展开运算符将 getter 混入 computed 对象
      "getNum4"
    ])
  }
};

3.使用module中的getter

module中的getter,又分为namespaced(命名空间)为true和false的情况。默认为false,则表示方位都是全局注册,与上边两种方法一致。

当为true时,则使用如下方法:

import { mapGetters } from "vuex";
export default {
  computed: {
    getNum1(a,b) {
      return this.$store.getters['moduleA/getNum1']
    },
    // 第一个参数是namespace命名空间,填上对应的module名称即可
    ...mapGetters("moduleA", {
      getNum2: "getNum2"
    }),
    ...mapGetters("moduleA", ["getNum3"])
  }
};

计算属性获取的getter值需要刷新才能更新

描述

 // state
 state: {
    leader: null
 },
 // getters
 getters: {
    getLead: state => state.leader
 }
 // mutations
 mutations: {
    setLead (state, data) {
      state.leader = data
    }
 },
// 页面中赋值
// 登录时改变state.leader的值
this.$store.commit('setLead', true)
// 组件中计算属性监听
import { mapGetters } from 'vuex'
computed: {
   leader () {
     ...mapGetters(['getLead'])
   }
 }

打印this.leader,直接获取计算属性值

刷新之后的打印结果

解决

增加监听函数watch,修改计算属性

computed: {
     ...mapGetters(['getLead'])
     //原来
   		//leader () {
    	// ...mapGetters(['getLead'])
   		//}
 }
watch: {
    // 监听getters数据 --- 'getLead'
    // 解决state数据可以更新,但getters数据需要刷新才能更新的问题
    getLead (val) {
      this.leader = val
      // this.leader是data中自定义的值,
      // 赋值之后,一定要重写之后的方法,
      // 不然只是取值,页面操作依然不会改变
      this.showVip() // 这是我页面上的方法名
    }
  },

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 浅谈vue2 单页面如何设置网页title

    浅谈vue2 单页面如何设置网页title

    这篇文章主要介绍了浅谈vue2 单页面如何设置网页title,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11
  • vite 项目中如何使用Sass

    vite 项目中如何使用Sass

    Vite默认集成了对Sass的支持,你只需要安装Sass本身即可,这篇文章主要介绍了vite 项目中如何使用Sass,需要的朋友可以参考下
    2024-04-04
  • VUE3页面div如何点击改变样式

    VUE3页面div如何点击改变样式

    这篇文章主要介绍了VUE3页面div如何点击改变样式问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • Vue Promise解决回调地狱问题实现方法

    Vue Promise解决回调地狱问题实现方法

    这篇文章主要介绍了Vue Promise解决回调地狱问题,总的来说这并不是一道难题,那为什么要拿出这道题介绍?拿出这道题真正想要传达的是解题的思路,以及不断优化探寻最优解的过程。希望通过这道题能给你带来一种解题优化的思路
    2023-01-01
  • 基于vue2框架的机器人自动回复mini-project实例代码

    基于vue2框架的机器人自动回复mini-project实例代码

    本篇文章主要介绍了基于vue2框架的机器人自动回复mini-project实例代码,具有一定的参考价值,有兴趣的可以了解一下
    2017-06-06
  • webpack项目调试以及独立打包配置文件的方法

    webpack项目调试以及独立打包配置文件的方法

    下面小编就为大家分享一篇webpack项目调试以及独立打包配置文件的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-02-02
  • vue实现顶部导航栏以及跳转

    vue实现顶部导航栏以及跳转

    这篇文章主要介绍了vue实现顶部导航栏以及跳转方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • vite+vue3.0+ts+element-plus快速搭建项目的实现

    vite+vue3.0+ts+element-plus快速搭建项目的实现

    本文将结合实例代码,介绍vite+vue3.0+ts+element-plus快速搭建项目的实现,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-06-06
  • 如何封装一个类似微信通讯录带有字母检索功能的vue组件

    如何封装一个类似微信通讯录带有字母检索功能的vue组件

    这篇文章主要介绍了如何封装一个类似微信通讯录带有字母检索功能的vue组件问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • Vue中的slot使用插槽分发内容的方法

    Vue中的slot使用插槽分发内容的方法

    这篇文章主要介绍了Vue中的slot使用插槽分发内容的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03

最新评论