有的组件中获取到 store 中的state,  需要对进行加工才能使用,computed 属性中就需要写操作函数,如果有多个组件中都需要进行这个操作,那么在各个组件中都写相同的函数,那就非常麻烦,这时可以把这个相同的操作写到store 中的getters,  每个组件只要引用getter 就可以了,非常方便。Getter 就是把组件中共有的对state 的操作进行了提取,它就相当于 对state 的computed. 所以它会获得state 作为第一个参数。

  假设我们在点击increment按钮的时候,再增加一个额外的数,那么就需要在display.vue 中显示我们多增加了哪个数,同时在increment.vue 中要获得这个数进行相加。state 状态中增加 anotherIncrement: 5.要获取到state 中的这个值,  在每个组件中都要写computed:  this.$store.state. countAnother, 这时就可以用getters, 然后在每个组件中computed 中使用getter.

display.vue 修改如下:

  1. <template>
  2. <div>
  3. <h3>Count is {{count}}</h3>
  4. <h3>AnoterIncrement is {{countAnother}}</h3>
  5. </div>
  6. </template>
  7.  
  8. <script>
  9. import {mapState} from "vuex";
  10. export default {
  11. computed: {
  12. ...mapState(["count"]),
  13. countAnother: function () { // 获取state
  14. return this.$store.getters.countAnother;
  15. }
  16. }
  17. }
  18. </script>

increment.vue 修改如下,这里dispatch中,只能接受一个参数,如果我们要传多个参数的话,需要把所有的参数组装成对象。

  1. <script>
  2. import {mapActions} from "vuex";
  3. export default {
  4. data() {
  5. return {
  6. incrementValue: 0
  7. }
  8. },
  9. computed: {
  10. show: function() {
  11. return this.$store.state.waiting;
  12. },
  13. countAnother: function () { // 获取getters
  14. return this.$store.getters.countAnother;
  15. }
  16. },
  17. methods: {
  18. ...mapActions(["increment","decrement"]),
  19. incrementWithValue() {
              // dispatch 只能接受一个参数,需要传对象参数
  20. this.$store.dispatch("incrementWithValue", { value:this.incrementValue, anotherValue: this.countAnother})
  21. }
  22. }
  23. }
  24. </script>

store.js 修改如下:

  1. const store = new Vuex.Store({
  2. state: {
  3. count:0,
  4. // 新增waiting 状态
  5. waiting: false,
  6. // 额外需要增加的数字
  7. anotherIncrement: 5
  8. },
  9. mutations: {
  10. // 加1
  11. INCREMENT(state) {
  12. state.count++;
  13. },
  14. // 减1
  15. DECREMENT(state) {
  16. state.count--
  17. },
  18. INCREMENT_WITH_VALUE(state, value){
  19. state.count = state.count + value.intValue + value.anotherValue;
  20. },
  21. // 显示和隐藏waiting
  22. SHOW_WAITING_MESSAGE(state){
  23. state.waiting = true;
  24. },
  25. HIDE_WAITING_MESSAGE(state){
  26. state.waiting = false;
  27. }
  28. },
  29. actions: {
  30. increment({commit}){
  31. commit("INCREMENT")
  32. },
  33. decrement({commit}){
  34. commit("DECREMENT")
  35. },
  36. incrementWithValue({commit}, value){
  37. commit("SHOW_WAITING_MESSAGE");
  38. let intValue = parseInt(value.value)
  39. let anotherValue = value.anotherValue
  40. setTimeout(function() {
  41.  
  42. if(isNaN(intValue)) {
  43. alert("Not an Interger")
  44. }else {
  45. commit("HIDE_WAITING_MESSAGE");
  46. commit("INCREMENT_WITH_VALUE", {intValue, anotherValue})
  47. }
  48. }, 2000)
  49. }
  50. },
  51. getters: { // getters
  52. countAnother: function (state) {
  53. return state.anotherIncrement
  54. }
  55. }
  56. })

  vuex 也提供了mapGetters 方法,和其的mapState,mapActions 是一样的,如果组件中使用的getters 和store 里面的getters 相同,那就用 数组形式,如果不相同,那就要用对象形式。

  increment.vue 修改一下:

  1. computed: {
  2. show: function() {
  3. return this.$store.state.waiting;
  4. },
  5. ...mapGetters{["countAnother"]}
    },

  到这里,vuex 中的 state, action,mutation, getter 等重要概念就介绍完了,但是,我们把所有的getters, actions, mutations 都写到的store 中,如果有很多的话,代码可读性太差,所以就需要 action 创建一个actions.js 文件,mutations 创建一个mutation.js文件,getters 也创建一个getters.js文件,state  作为主要的入口文件命名为index.js,把这四个js文件放到store 文件夹中。

state所在的文件命名为index.js 还和 nodejs 加载模块有关。如果不命名为index.js , 那假设命名为store.js.

  在store.js, 我们暴露出通过 new Vuex.Store 构造函数生成的store 对象(export default new Vuex.Store({...})), 这个store 对象需要在 main.js 中引入,然后注入到vue 根实例中。所以在 main.js 中需要写入 import store from './store/store.js',  后面的路径就比较长了。如果我们命名为 index.js, 我们可以直接写 import store from './store', 后面的路径直接到文件夹名就可以了,index.js 可以省略。node 在加载文件夹模块的时候,有如下规定:

   var mode = require(“./moduleDir”);

  如果moduleDir 是一个文件夹名,Node 就会在指定的文件夹下查找模块。Node 会假定该文件夹是一个包,并试验查找包定义。 包定义在名为 package.json 文件中。如果文件夹中没有package.json, 那么就会查找index.js文件,相当于加载 var mode = require(“./moduleDir/index.js”). 如果有package.json 文件,就会查找文件中的 main 属性,如下package.json文件, 相当于加载 var mode = require(“./moduleDir/lib/mymodldule.js”)

  1. { name”: myModule”, main : “./lib/myModule.js”}

在src 目录下,新建store.js 文件夹,里面新建getters.js, actions.js, mutations.js, index.js 文件。

getters.js 文件如下:

  1. export default {
  2. countAnother: function (state) {
  3. return state.anotherIncrement
  4. }
  5. }

actions.js 文件如下:

  1. export default {
  2. increment({commit}){
  3. commit("INCREMENT")
  4. },
  5. decrement({commit}){
  6. commit("DECREMENT")
  7. },
  8. incrementWithValue({commit}, value){
  9. commit("SHOW_WAITING_MESSAGE");
  10. let intValue = parseInt(value.value)
  11. let anotherValue = value.anotherValue
  12. setTimeout(function() {
  13.  
  14. if(isNaN(intValue)) {
  15. alert("Not an Interger")
  16. }else {
  17. commit("HIDE_WAITING_MESSAGE");
  18. commit("INCREMENT_WITH_VALUE", {intValue, anotherValue})
  19. }
  20. }, 2000)
  21. }
  22. }

muations 文件如下:

  1. export default {
  2. // 加1
  3. INCREMENT(state) {
  4. state.count++;
  5. },
  6. // 减1
  7. DECREMENT(state) {
  8. state.count--
  9. },
  10. INCREMENT_WITH_VALUE(state, value){
  11. state.count = state.count + value.intValue + value.anotherValue;
  12. },
  13. // 显示和隐藏waiting
  14. SHOW_WAITING_MESSAGE(state){
  15. state.waiting = true;
  16. },
  17. HIDE_WAITING_MESSAGE(state){
  18. state.waiting = false;
  19. }
  20. }

index.js 文件如下:

  1. import Vue from "vue";
  2. import Vuex from "vuex";
  3. Vue.use(Vuex);
  4.  
  5. // 引入actions, mutations, getters
  6. import actions from "./actions.js"
  7. import mutations from "./mutations.js"
  8. import getters from "./getters.js"
  9.  
  10. const state = {
  11. count:0,
  12. // 新增waiting 状态
  13. waiting: false,
  14. // 额外需要增加的数字
  15. anotherIncrement: 5
  16. }
  17.  
  18. export default new Vuex.Store({
  19. state,
  20. mutations,
  21. actions,
  22. getters
  23. })

vuex2.0 基本使用(3) --- getter的更多相关文章

  1. (转)vuex2.0 基本使用(3) --- getter

    有的组件中获取到 store 中的state,  需要对进行加工才能使用,computed 属性中就需要写操作函数,如果有多个组件中都需要进行这个操作,那么在各个组件中都写相同的函数,那就非常麻烦,这 ...

  2. Vuex2.0+Vue2.0构建备忘录应用实践

    一.介绍Vuex Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化,适合于构建中大型单页应用. ...

  3. vuex2.0.0爬坑记录 -- mutations的第一个参数state不能解构

    今天在学习vuex的过程中,遇到了一个很困扰人的问题,最终利用vuex的状态快照工具logger解决了问题. 问题是这样的,我在子组件中使用了mapState()函数来将状态映射至子组件中,使子组件能 ...

  4. vuex2.0+两个小例子

    首先vuex概念比较多,一定要搞懂里面的概念,可以参考官网Vuex2.0概念,我写此文的目的是希望能对前端爱好者提供个参考,加深对vuex2.0各核心概念的理解. 废话少说,直接上干货.这是官网上的一 ...

  5. Vuex2.0边学边记+两个小例子

    最近在研究Vuex2.0,搞了好几天终于有点头绪了. 首先vuex概念比较多,一定要搞懂里面的概念,可以参考官网Vuex2.0概念,我写此文的目的是希望能对前端爱好者提供个参考,加深对vuex2.0各 ...

  6. 【16】vuex2.0 之 getter

    有的组件中获取到 store 中的state,  需要对进行加工才能使用,computed 属性中就需要写操作函数,如果有多个组件中都需要进行这个操作,那么在各个组件中都写相同的函数,那就非常麻烦,这 ...

  7. vuex2.0源码分析

    当我们用vue在开发的过程中,经常会遇到以下问题 多个vue组件共享状态 Vue组件间的通讯 在项目不复杂的时候,我们会利用全局事件bus的方式解决,但随着复杂度的提升,用这种方式将会使得代码难以维护 ...

  8. Vue-cli+Vue.js2.0+Vuex2.0+vue-router+es6+webpack+node.js脚手架搭建和Vue开发实战

    Vue.js是一个构建数据驱动的web界面的渐进式框架.在写这边文章时Vue版本分为1.0++和2.0++,这个是基于Vue2.0的项目. Vue-cli是构建单页应用的脚手架,这个可是官方的. Vu ...

  9. vuex2.0 基本使用(4) --- modules

    vue 使用的是单一状态树对整个应用的状态进行管理,也就是说,应用中的所有状态都放到store中,如果是一个大型应用,状态非常多, store 就会非常庞大,不太好管理.这时vuex 提供了另外一种方 ...

随机推荐

  1. C#总结(五)调用C++动态库(类型对照)

    函数调用导致堆栈不对称.原因可能是托管的 PInvoke 签名与非托管的目标签名不匹配. 在dllimport中加入CallingConvention参数就行了, [DllImport(PCAP_DL ...

  2. UITableView的编辑操作

    继续上篇UITableView和UITableViewController, 打开BNRItemsViewController.m,在类扩展中添加如下属性: @property (nonatomic, ...

  3. elasticsearch(6.2.3)安装Head插件

    一.安装elasticsearch,参照:https://www.cnblogs.com/dyh004/p/8872443.html 二.安装nodejs,参照:https://www.runoob. ...

  4. python全栈开发慕课网

    前端 web框架: flask:简单.轻量.灵活性大 (官网,stck overflowa); 目录结构:配置,发布,资源,日志,测试... 前后端协作:整体发布,前后端分离发布 django:简单, ...

  5. Five Dimensional Points CodeForces - 851C (计算几何+暴力)

      C. Five Dimensional Points time limit per test 2 seconds memory limit per test 256 megabytes input ...

  6. 使用faker去构造一个User-Agent

    faker可以仿造各种各样的信息,可以使用faker去构造一个User-Agent from faker import Factory f = Factory.create() 'User-Agent ...

  7. 实分析p78 两个解释

    1. 是为了存在一个充分大的J,使得,当j大于J.会满足.x是满足能一致收敛到f(x)自变量取得集合,, 是为了允许有限个 前面的不成立,是对所有的k都成立,让k取很大,可以很小 2.是函数列收敛到f ...

  8. openstack-虚拟化模型

    一. 虚拟化模型 1.虚拟化模型 图1 虚拟化模型 图2 KVM架构 2.KVM模块 处理器虚化 内存虚化 3.QEMU设备模型 其它虚化(网卡.声卡.显卡等)

  9. Memcached 集群架构与memcached-session-manager

    Memcached 集群架构方面的问题_知识库_博客园https://kb.cnblogs.com/page/69074/ memcached-session-manager配置 - 学习中间件调优管 ...

  10. 手机端图像编辑上传-cropper

    编辑头像,实现相册,照像功能,并能缩放裁剪功能,可自定义UI,引用'cropper.js', 'exif.js' /*初始化裁剪插件*/ var screenWidth = $(window).wid ...