一文教会你认识Vuex状态机

一. 速识概念:

1. 组件之间共享数据的方式:

通常有以下几种方式:

  1. 父向子传值:v-bind 属性绑定;
  2. 子向父传值:v-on 事件绑定;
  3. 兄弟组件之间共享数据:EventBus;

2. vuex是什么:

  1. 按照官方的话来说,Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。Vuex 也集成到 Vue 的官方调试工具 devtools extension (opens new window),提供了诸如零配置的 time-travel 调试、状态快照导入导出等高级调试功能。
  2. 简单来说,Vuex就是实现组件全局状态(数据)管理的一种机制,可以方便的实现组件之间数据的共享。

3.使用vuex优点:

  1. 能够在vuex中集中管理共享的数据,易于开发和后期维护。
  2. 能够高效地实现组件之间的数据共享, 提高开发效率。
  3. 存储在vuex中的数据都是响应式的,能够实时保持数据与页面的同步。
  4. 解决了非父子组件的消息传递(将数据存放在state中)。
  5. 减少了AJAX请求次数,有些情景可以直接从内存中的state获取。

一般情况下,只有组件之间共享的数据,才有必要存储到vuex中。而对于组件中的私有数据,就没必要了,依旧存储在组件自身的data中即可。当然,如果你想要都存在vuex中也是可以的。

二. 基本使用:

1.安装依赖包:

npm install vuex --save

2.导入依赖包:

import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

3.创建store对象:

复制代码

import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

const store = new Vuex.Store({
//state中存放的就是全局共享的数据
  state: {
    count: 0
  }
})

复制代码

4. 将store对象挂载到vue实例中:

new Vue({
  el: '#app',
  store
})

此时所有组件就可以从store中获取数据了。

三.创建项目:

下面为创建一个vue项目流程,后面会有案例:

(1)打开cmd窗口输入 vue ui 打开vue的可视化面板:

在这里插入图片描述
(2)选择新建项目路径:

在这里插入图片描述
(3)命名:

在这里插入图片描述
(4)手动选择配置,注意用的是vue2版本:
在这里插入图片描述
在这里插入图片描述
(5)创建:

在这里插入图片描述

(6)下一步:

在这里插入图片描述
(7)创建成功,到对应目录打开vscode开始编程:
在这里插入图片描述
(8)运行项目:

在这里插入图片描述

四. 讲解前提:

前提(注意):

写一个计数器小案例,从案例中配合概念能更快上手vuex。所以下面核心概念中的代码部分是基于这个小案例来演示的。目标:写两个子组件,有一个公共count值,在父组件中,其中一个组件实现点击后count值减1,一个组件实现点击后count值增1。

父组件 App.vue 初始代码:

复制代码



复制代码

子组件Add.vue初始代码:

复制代码


复制代码

子组件Reduce.vue初始代码:

复制代码


复制代码

store对象初始代码为:

复制代码

import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

export default new Vuex.Store({
  state: {
    count: 0
  }
})

复制代码

初始效果:

在这里插入图片描述

五.核心概念:

1.state:

按照官方的话来说,如下:Vuex 使用单一状态树——是的,用一个对象就包含了全部的应用层级状态。至此它便作为一个“唯一数据源 (SSOT)”而存在。这也意味着,每个应用将仅仅包含一个 store 实例。

简单来说,就是State提供唯一的公共数据源, 所有共享的数据都要统一放到Store的State中进行存储。

https://wenwen.sogou.com/question/q923241666415362792.htm
https://www.im286.net/thread-24257833-1.html
https://www.im286.net/thread-24257835-1.html
https://www.meipian.cn/3lptd8tx?share_depth=1
https://www.jianshu.com/p/826b997c0dd5
https://xueqiu.com/4824316523/180286177
https://blog.csdn.net/yunkeyi/article/details/117034116
https://blog.51cto.com/u_15205168/2786383
https://tieba.baidu.com/p/7360776650
https://weibo.com/ttarticle/p/show?id=2309404638609700683839
https://zhidao.baidu.com/question/1455017293367081300.html
 

1.1 组件中访问state的第一种方式:

组件中直接输入以下命令:

如在Add.vue子组件中引用:

复制代码


//下面部分代码跟前面一样无改变,所以省略了

复制代码

看效果,显示了count的值为0:

在这里插入图片描述

1.2 组件中访问state的第二种方式:

(1)从 vuex 中按需导入 mapState 函数

import { mapState } from 'vuex'

(2)通过刚才导入的mapState函数,将当前组件需要的全局数据,映射为当前组件的computed计算属性:

computed: {
   ...mapState([count])
}

小知识:computed用来监控自己定义的变量,该变量不在data里面声明,直接在computed里面定义,然后就可以在页面上进行双向数据绑定展示出结果或者用作其他处理;

如在Reduce.vue子组件中引用:

复制代码


复制代码

看效果,同样显示了count的值为0:

在这里插入图片描述

2. mutation:

按照官方的话来说,更改 Vuex 的 store 中的状态的唯一方法是提交 mutation。Vuex 中的 mutation 非常类似于事件:每个 mutation 都有一个字符串的 事件类型 (type) 和 一个 回调函数 (handler)。这个回调函数就是我们实际进行状态更改的地方,并且它会接受 state 作为第一个参数。

简单来说就是Mutation用于变更Store中的数据。
①只能通过mutation变更Store数据,不可以直接操作Store中的数据。
②通过这种方式虽然操作起来稍微繁琐一些,但是可以集中监控所有数据的变化。

比如,要实现count值自增加1的操作,那就在先motations里定义一个自增加1的函数。然后对应子组件想用,该组件就直接引入mutation并调用对应的函数就好。

如下,Add.vue子组件要实现自增加1功能:先在状态机里的mutations里定义一个能实现自增的函数add:

复制代码

export default new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    //自增加1函数
    add(state){
      state.count++
    }
  }
})

复制代码

2.1 触发mutation的第一种方式:

Add.vue子组件里给按钮绑定点击事件,并触发mutation:

复制代码


复制代码

看效果实现了点击自增:

在这里插入图片描述

2.2 触发mutation并传参数:

当然,当组件里调用mutation里函数时,也是可以传参数的。比如,有一个自增函数,但增多少看调用时传入的参数:

复制代码

export default new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    // 传入参数,第一个一定是state,第二个为传入的参数
    //自增加 n 的函数
    addN(state,n){
      state.count+= n
    }
  }
})

复制代码

对应组件调用时要传入参数:

复制代码

methods: {
          btnAdd2() {
              // 引入mutation的方式,触发addN函数
              // 并传参,自增加6吧
              this.$store.commit('addN',6)
          }
      }

复制代码

2.3 触发mutation的第二种方式:

(1)从 vuex 中按需导入 mapMutations 函数

import { mapMutations } from 'vuex'

(2)通过刚才导入的mapMutations函数,将需要的mutations函数,映射为当前组件的methods方法:

methods: {
   ...mapMutations(['add','addN'])
}

实战,实现Reduce.vue组件的点击自减1的功能要求:

状态机添加自减函数:

复制代码

export default new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    //自增加1函数
    add(state){
      state.count++
    },
    // 自减1的函数
    sub(state){
      state.count--
    }
  }
})

复制代码

你可能感兴趣的:(一文教会你认识Vuex状态机)