详解vue组件化开发-vuex状态管理库


Posted in Javascript onApril 10, 2017

Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。Vuex 也集成到 Vue 的官方调试工具 devtools extension,提供了诸如零配置的 time-travel 调试、状态快照导入导出等高级调试功能。

以上是vuex的官方文档对vuex的介绍,官方文档对vuex的用法进行了详细的说明。这里就不再细讲vuex的各个用法,写这篇博客的目的只是帮助部分同学更快地理解并上手vuex。

为什么要用vuex

不知道现在读这篇博客的同学是否有看过Vue2.0子父组件之间通信,子父组件之间的基本通信方式。我们通信的目的往往就是在组件之间传递数据或组件的状态(这里将数据和状态统称为状态),进而更改状态。但可以看到如果我们通过最基本的方式来进行通信,一旦需要管理的状态多了,代码就会变得十分混乱。对所有状态的管理便会显得力不从心,尤其是多人合作的时候。

此时vuex出现了,他就是帮助我们把公用的状态全抽出来放在vuex的容器中,然后根据一定的规则来进行管理

Vuex的核心

vuex由以下几部分组成:

  1. state
  2. mutations
  3. getters
  4. actions
  5. modules

state里面就是存放项目中需要多组件共享的状态

mutations就是存放更改state里状态的方法

getters就是从state中派生出状态,比如将state中的某个状态进行过滤然后获取新的状态。

actions就是mutation的加强版,它可以通过commit mutations中的方法来改变状态,最重要的是它可以进行异步操作。

modules顾名思义,就是当用这个容器来装这些状态还是显得混乱的时候,我们就可以把容器分成几块,把状态和管理规则分类来装。这和我们创建js模块是一个目的,让代码结构更清晰。

实例来理解Vuex

// 实例化vuex状态库
var vuexStore = new Vuex.Store({
 state:{
  message:'Hello World',
  bookList:[
   {
    name:'javascript权威指南',
    price:100,
    en:'jq'
   },
   {
    name:'angularjs权威指南',
    price:80,
    en:'aq'
   },
   {
    name:'HTTP权威指南',
    price:50,
    en:'hq'
   }
  ]
 },
 mutations:{
  //同步
  showMessage:function(state,data){
   state.message = 'Store mutations changed this words。'+data;
  }
  addBook:function(state,data){
   state.bookList.push(data)
  }
 },
 getters:{
  filterPrice:function(state){
   var narr = [];
   for(var i = 0;i<state.bookList.length;i++){
    state.bookList[i].price<85 ? narr.push(state.bookList[i]) : null;
   }
   return narr;
  }
 },
 actions:{
  //异步操作
  addBook:function(context){
   setTimeout(function(){
    context.commit('addBook',{name:'HTML5权威指南',price:75});
   },2000);
  }
 },
 modules:{
  a:storeA,b:storeB
 }
});

// vue 实例
var vm = new Vue({
el:'app',

store:VuexStore,

methods:{
  showMessage:function(){



this.$store.commit('showMessage','荷载数据')


},
  filterList:function(){
   return this.store.getters.filterPrice();
  },
  addBooks:function(){



this.$store.dispatch('addBook')


},

}
});

【state】vuex核心概念有五个,试想当我们把所有的状态从各个组件抽出来,放入了state中:message和bookList;

【mutations】某个时候,某个组件中,我们需要把state中的message改变数据,我们要通过调用commit方法提交到mutations对应的事件:commit('showMessage'),这样就会调用mutations里showMessage方法;调用方法是如上面代码中57行的方式;

【getters】某个时间,某个组件我们需要获得bookList中价格小于85的所有数据,vuex中允许我们通过getters来获取:使用方法如上代码中60行

【actions】这个是mutations的强化部分,只是这个里面的函数可以异步操作,比如网络请求等等;这里面的方法如果要更改状态,最好要通过commit()函数提交到mutations里去处理。官方是这么说的。在实例里调用一般是通过dispatch('funName')来调用的;例如实例中:66行代码

【关于moduls】modules其实就是多个状态管理库,放在一个对象里,比如我们有2个状态库:storeA,storeB。我们在modules里就和上面代码中50行的写法是一样的。

 在取值的时候就直接在实例里调用:this.$store.state.a即可返回storeA这个store里的状态。

这里有一个点要注意一下:所有子模块里的getters对象里的方法会被合并到$store里,如果不同子模块里有重名的方法,那么会报错;

但是所有子模块里actions和mutations中的方法不会被合并,重名也不会报错。但是当你dispatch或者commit一个同名的事件的时候,会依次执行每一个子模块中的事件。

所以在不同子模块的actions和mutations中不要写重复的函数名称;

使用Vuex

下面我们来讲一下怎么引入一个Vuex协助我们管理状态:

首先当然要引入Vuex.js;

然后,我们新建一个vuex实例

var store = new VuexStore({
 state:{
  } ,
  mountations:{
  },  
 })

创建好store后我们需要把这个store注入到vue的实例和组件中,

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

然后我们就能像上面介绍的方法使用了。

最后多说一嘴,官方建议的目录结构是吧mutations,actions,getters等一系列,都分开放在不同的目录,便于多人开发与维护。

vue到此已经研究了很多。行百里者半九十,还需要深入研究。个人对vue2.0的总结demo已上传至gitHub。地址:https://github.com/HUA1/vue2-summary.git

本文到此结束,所涉及的vue版本是2.0.x;vuex版本是:2.2.1。希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
document.documentElement的一些使用技巧
Apr 18 Javascript
解析Javascript中中括号“[]”的多义性
Dec 03 Javascript
js时间日期格式化封装函数
Dec 02 Javascript
JavaScript返回上一页的三种方法及区别介绍
Jul 04 Javascript
jQuery增加、删除及修改select option的方法
Aug 19 Javascript
jQuery 添加样式属性的优先级别方法(推荐)
Jun 08 jQuery
angularjs+bootstrap实现自定义分页的实例代码
Jun 19 Javascript
解决ionic和angular上拉加载的问题
Aug 03 Javascript
前端js中的事件循环eventloop机制详解
May 15 Javascript
微信小程序解析富文本过程详解
Jul 13 Javascript
微信小程序webview组件交互,内联h5页面并网页实现微信支付实现解析
Aug 16 Javascript
LayUI switch 开关监听 获取属性值、更改状态的方法
Sep 21 Javascript
vue中如何引入jQuery和Bootstrap
Apr 10 #jQuery
详解vue.js全局组件和局部组件
Apr 10 #Javascript
Vue2.0使用过程常见的一些问题总结学习
Apr 10 #Javascript
jQuery插件FusionCharts绘制2D柱状图和折线图的组合图效果示例【附demo源码】
Apr 10 #jQuery
jQuery插件FusionCharts绘制2D环饼图效果示例【附demo源码】
Apr 10 #jQuery
vue构建单页面应用实战
Apr 10 #Javascript
bootstrap suggest下拉框使用详解
Apr 10 #Javascript
You might like
上海永华YH-R296(华普R-96)12波段立体声收音机的分析和打理
2021/03/02 无线电
APMServ使用说明
2006/10/23 PHP
php编写批量生成不重复的卡号密码代码
2015/05/14 PHP
php通过curl添加cookie伪造登陆抓取数据的方法
2016/04/02 PHP
php解决和避免form表单重复提交的几种方法
2016/08/31 PHP
php实现微信扫码自动登陆与注册功能
2016/09/22 PHP
PHP面向对象之里氏替换原则简单示例
2018/04/08 PHP
JavaScript 设计模式之组合模式解析
2010/04/09 Javascript
js判断undefined变量类型使用typeof
2013/06/03 Javascript
JavaScript三元运算符的多种使用技巧
2015/04/16 Javascript
js提交form表单,并传递参数的实现方法
2016/05/25 Javascript
Bootstrap被封装的弹层
2016/07/20 Javascript
jQuery 更改checkbox的状态,无效的解决方法
2016/07/22 Javascript
实例解析Array和String方法
2016/12/14 Javascript
Bootstrap页面标题Page Header的实现方法
2017/03/22 Javascript
layui表格实现代码
2017/05/20 Javascript
JS判断字符串是否为整数的方法--简单的正则判断
2018/07/23 Javascript
在vue中实现点击选择框阻止弹出层消失的方法
2018/09/15 Javascript
微信小程序 textarea 层级过高问题简单解决方案
2019/10/14 Javascript
Vue中的nextTick作用和几个简单的使用场景
2021/01/25 Vue.js
Python打包方法Pyinstaller的使用
2018/10/09 Python
Python利用递归实现文件的复制方法
2018/10/27 Python
Pandas_cum累积计算和rolling滚动计算的用法详解
2019/07/04 Python
Python Web版语音合成实例详解
2019/07/16 Python
浅谈Django中的QueryDict元素为数组的坑
2020/03/31 Python
python中round函数如何使用
2020/06/19 Python
const和static readonly区别
2013/05/20 面试题
白酒市场营销方案
2014/02/25 职场文书
人事专员的职责
2014/02/26 职场文书
2014年平安创建工作总结
2014/11/24 职场文书
高效笔记技巧分享:学会这些让你不再困扰
2019/09/04 职场文书
启动Tomcat时出现大量乱码的解决方法
2021/06/21 Java/Android
python利用pandas分析学生期末成绩实例代码
2021/07/09 Python
多人盗宝《绿林侠盗》第三赛季4.5上线 跨平台实装
2022/04/03 其他游戏
Python列表的索引与切片
2022/04/07 Python
Python中生成随机数据安全性、多功能性、用途和速度方面进行比较
2022/04/14 Python