Vuex 入门教程


Posted in Javascript onJanuary 10, 2018

Vuex 是什么?

官方给出的解释:Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。

相信很多新选手看完这段话有种绝望的感觉。开始我也是这样的,后来我想到了一个比方!

比如某年级有5个小班,每个小班有25个同学,但是只有一个老师授课,假如5个小班就对应着5个组件,每个班的25个同学就相当于每个组件中的25条数据,这个老师就相当于 vuex ,老师讲的课就相当于每一条数据。要保证每个同学受到同样的教育,就需要这个老师把每节课分别讲5遍,还不能保证每个班的同学听到的效果相同。一段时间后,老师觉得这样特别麻烦还很累,就想了一个办法,找了一个大教室,把这5个小班的同学合并到一起,这样每个课程只需要讲一次就好啦,而且还保证了每个班的同学听到的效果相同。这就是 vuex 的作用,把各个组件中用到的数据统一管理,同步发放,省时省心省力。

那这个 vuex 怎么用呢?让我们从一个简单的 Vue 计数应用开始

一、基本用法

1. 初始化并创建一个项目

vue init webpack-simple vuex-demo
cd vuex-demo
npm install

2. 安装 vuex

npm install vuex -S

3. 在 src 目录下创建 store.js 文件,并在 main.js 文件中导入并配置

store.js 中写入

import Vue from 'vue'
//引入 vuex 并 use
import Vuex from 'vuex'
Vue.use(Vuex)

main.js 文件

import Vue from 'vue'
import App from './App.vue'
import store from './assets/store' //导入 store 对象

new Vue({
 //配置 store 选项,指定为 store 对象,会自动将 store 对象注入到所有子组件中,在子组件中通过 this.$store 访问该 store 对象 
 store, 
 el: '#app',
 render: h => h(App)
})

4. 编辑 store.js 文件

在应用 vuex 之前,我们还是需要看懂这个流程图,其实很简单。

Vuex 入门教程

vuex

① Vue Components 是我们的 vue 组件,组件会触发(dispatch)一些事件或动作,也就是图中的 Actions;
② 我们在组件中发出的动作,肯定是想获取或者改变数据的,但是在 vuex 中,数据是集中管理的,我们不能直接去更改数据,所以会把这个动作提交(Commit)到 Mutations 中;
③ 然后 Mutations 就去改变(Mutate)State 中的数据;
④ 当 State 中的数据被改变之后,就会重新渲染(Render)到 Vue Components 中去,组件展示更新后的数据,完成一个流程。

Vuex 的核心是 Store(仓库),相当于是一个容器,一个 Store 实例中包含以下属性的方法:

state 定义属性(状态 、数据)

store.js 中写入

// 定义属性(数据)
var state = {
 count:6
}
// 创建 store 对象
const store = new Vuex.Store({
 state
})

// 导出 store 对象
export default store;

方式1、 在 app.vue 中就能通过 this.$store 访问该 store 对象 ,获取该 count 。

<template>
 <div id="app">
 //把 count 方法直接写入,可自己执行
 <h1>{{count}}</h1>
 </div>
</template>

<script>
export default {
 name: 'app',
 computed:{
 count(){
  //返回获取到的数据
  return this.$store.state.count
 }
 }
}
</script>

方式2、vuex 提供的 mapGetters 和 mapActions 来访问

mapGetters 用来获取属性(数据)

① 在 app.vue 中引入 mapGetters

import {mapGetters} from 'vuex'

② 在 app.vue 文件的计算属性中调用 mapGetters 辅助方法,并传入一个数组,在数组中指定要获取的属性  count

<script>
import {mapGetters,mapActions} from 'vuex'
export default {
 name: 'app',
 computed:mapGetters([
 //此处的 count 与以下 store.js 文件中 getters 内的 count 相对应
 'count'
 ])
}
</script>

③ 在 store.js 中定义 getters 方法并导出

getters 用来获取属性

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)

// 定义属性(数据)
var state = {
 count:6
}
// 定义 getters
var getters={
 //需要传个形参,用来获取 state 属性
 count(state){
  return state.count
 }
}
// 创建 store 对象
const store = new Vuex.Store({
 state,
 getters
})

// 导出 store 对象
export default store;

这样页面上就会显示传过来的数据了!接下来我们来通过动作改变获取到的数据

④在 store.js 中定义 actions 和 mutations 方法并导出

actions 定义方法(动作)

commit 提交变化,修改数据的唯一方式就是显示的提交 mutations

mutations 定义变化,处理状态(数据)的改变

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)

// 定义属性(数据)
var state = {
 count:6
}

// 定义 getters
var getters={
 count(state){
  return state.count
 }
}

// 定义 actions ,要执行的动作,如流程的判断、异步请求
const actions ={
 // ({commit,state}) 这种写法是 es6 中的对象解构
 increment({commit,state}){
  //提交一个名为 increment 的变化,名字可自定义,可以认为是类型名,与下方 mutations 中的 increment 对应
  //commit 提交变化,修改数据的唯一方式就是显式的提交 mutations
  commit('increment') 
 }
}

// 定义 mutations ,处理状态(数据) 的改变
const mutations ={
 //与上方 commit 中的 ‘increment' 相对应
 increment(state){
  state.count ++;
 }
}
// 创建 store 对象
const store = new Vuex.Store({
 state,
 getters,
 actions,
 mutations
})

// 导出 store 对象
export default store;

⑤ 在 app.vue 中引入 mapActions ,并调用

mapActions 用来获取方法(动作)

import {mapGetters,mapActions} from 'vuex'

调用 mapActions 辅助方法,并传入一个数组,在数组中指定要获取的方法 increment

<template>
 <div id="app">
 //这个 increment 方法与下面 methods 中的 increment 相对应
 <button @click="increment">增加</button>
 <button>减少</button>
 <h1>{{count}}</h1>
 </div>
</template>

<script>
import {mapGetters,mapActions} from 'vuex'
export default {
 name: 'app',
 computed:mapGetters([
 'count'
 ]),
 methods:mapActions([
 //该 increment 来自 store.js 中导出的 actions 和 mutations 中的 increment 
 'increment',
 ])
}
</script>

这样就能通过 button 来改变获取到的 count 了。

看起来确实是挺绕的,需要在理解了原理的情况下,再细细琢磨,加深理解。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
基于jQuery的js分页代码
Jun 10 Javascript
基于jquery实现的类似百度搜索的输入框自动完成功能
Aug 23 Javascript
jQuery的显示和隐藏方法与css隐藏的样式对比
Oct 18 Javascript
js如何获取兄弟、父类等节点
Jan 06 Javascript
JS日期加减,日期运算代码
Nov 05 Javascript
jQuery获取字符串中出现最多的数
Feb 22 Javascript
详解Wondows下Node.js使用MongoDB的环境配置
Mar 01 Javascript
js中document.referrer实现移动端返回上一页
Feb 22 Javascript
JavaScript程序设计高级算法之动态规划实例分析
Nov 24 Javascript
ES6知识点整理之函数对象参数默认值及其解构应用示例
Apr 17 Javascript
JS实现checkbox互斥(单选)功能示例
May 04 Javascript
Vue作用域插槽实现方法及作用详解
Jul 08 Javascript
js实现上传并压缩图片效果
Jan 10 #Javascript
web前端vue之CSS过渡效果示例
Jan 10 #Javascript
Vue.js分页组件实现:diVuePagination的使用详解
Jan 10 #Javascript
利用ECharts.js画K线图的方法示例
Jan 10 #Javascript
微信小程序实现图片上传功能实例(前端+PHP后端)
Jan 10 #Javascript
微信小程序实现传参数的几种方法示例
Jan 10 #Javascript
React中常见的动画实现的几种方式
Jan 10 #Javascript
You might like
用 Composer构建自己的 PHP 框架之基础准备
2014/10/30 PHP
Thinkphp中数据按分类嵌套循环实现方法
2014/10/30 PHP
通过php修改xml文档内容的方法
2015/01/23 PHP
javascript string字符串优化问题
2011/07/31 Javascript
通过JavaScript控制字体大小的代码
2011/10/04 Javascript
JavaScript模板入门介绍
2012/09/26 Javascript
jquery.ajax之beforeSend方法使用介绍
2014/12/08 Javascript
JavaScript实现定时隐藏与显示图片的方法
2015/08/06 Javascript
基于bootstrap实现广告轮播带图片和文字效果
2016/07/22 Javascript
解决html-jquery/js引用外部图片时遇到看不了或出现403的问题
2017/09/22 jQuery
Vue+mui实现图片的本地缓存示例代码
2018/05/24 Javascript
layui的面包屑或者表单不显示的解决方法
2019/09/05 Javascript
mpvue实现微信小程序快递单号查询代码
2020/04/03 Javascript
Node.js API详解之 module模块用法实例分析
2020/05/13 Javascript
Vue路由切换页面不更新问题解决方案
2020/07/10 Javascript
微信小程序实现分页加载效果
2020/11/19 Javascript
Python基于ThreadingTCPServer创建多线程代理的方法示例
2018/01/11 Python
python如何修改装饰器中参数
2018/03/20 Python
Python将DataFrame的某一列作为index的方法
2018/04/08 Python
在IPython中进行Python程序执行时间的测量方法
2018/11/01 Python
在Python中实现shuffle给列表洗牌
2018/11/08 Python
对python中基于tcp协议的通信(数据传输)实例讲解
2019/07/22 Python
Windows系统下pycharm中的pip换源
2020/02/23 Python
关于jupyter打开之后不能直接跳转到浏览器的解决方式
2020/04/13 Python
Django 实现 Websocket 广播、点对点发送消息的代码
2020/06/03 Python
怎么解决pycharm license Acti的方法
2020/10/28 Python
竞聘演讲稿范文
2014/01/12 职场文书
企业务虚会发言材料
2014/10/20 职场文书
年度考核表个人总结
2015/03/06 职场文书
食品安全主题班会
2015/08/13 职场文书
教师法制教育培训学习心得体会
2016/01/14 职场文书
晶体管单管来复再生式收音机
2021/04/22 无线电
详解MySQL数据库千万级数据查询和存储
2021/05/18 MySQL
Java实现多线程聊天室
2021/06/26 Java/Android
Python中的变量与常量
2021/11/11 Python
javascript Number 与 Math对象的介绍
2021/11/17 Javascript