详解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 相关文章推荐
自己实现string的substring方法 人民币小写转大写,数字反转,正则优化
Sep 02 Javascript
JS获取图片lowsrc属性的方法
Apr 01 Javascript
Angular发布1.5正式版,专注于向Angular 2的过渡
Feb 18 Javascript
深入解析JavaScript中的arguments对象
Jun 12 Javascript
js方法数据验证的简单实例
Sep 17 Javascript
Javascript 函数的四种调用模式
Nov 05 Javascript
jquery插件bootstrapValidator数据验证详解
Nov 09 Javascript
JS简单获取日期相差天数的方法
Apr 24 Javascript
详解RequireJs官方使用教程
Oct 31 Javascript
vue如何在自定义组件中使用v-model
May 14 Javascript
解决VueCil代理本地proxytable无效报错404的问题
Nov 07 Javascript
vue里使用create, mounted调用方法
Apr 26 Vue.js
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
PHP的宝库目录--PEAR
2006/10/09 PHP
PHP简单系统数据添加以及数据删除模块源文件下载
2008/06/07 PHP
Laravel 将数据表的数据导出,并生成seeds种子文件的方法
2019/10/09 PHP
php设计模式之策略模式实例分析【星际争霸游戏案例】
2020/03/26 PHP
浅谈PHP中的那些魔术常量
2020/12/02 PHP
PHP的imageTtfText()函数深入详解
2021/03/03 PHP
用JavaScript脚本实现Web页面信息交互
2006/12/21 Javascript
Jquery实现搜索框提示功能示例代码
2013/08/13 Javascript
用javascript添加控件自定义属性解析
2013/11/25 Javascript
使用js获取图片原始尺寸
2014/12/03 Javascript
JavaScript显示表单内元素数量的方法
2015/04/02 Javascript
基于jquery实现表格无刷新分页
2016/01/07 Javascript
微信小程序实现移动端滑动分页效果(ajax)
2017/06/13 Javascript
Vue通过URL传参如何控制全局console.log的开关详解
2017/12/07 Javascript
Angular利用内容投射向组件输入ngForOf模板的方法
2018/03/05 Javascript
mpvue 如何使用腾讯视频插件的方法
2018/07/16 Javascript
构建Vue大型应用的10个最佳实践(小结)
2019/11/07 Javascript
关于vue利用postcss-pxtorem进行移动端适配的问题
2019/11/20 Javascript
antd的select下拉框因为数据量太大造成卡顿的解决方式
2020/10/31 Javascript
Python跨文件全局变量的实现方法示例
2017/12/10 Python
python manage.py runserver流程解析
2019/11/08 Python
Python使用QQ邮箱发送邮件报错smtplib.SMTPAuthenticationError
2019/12/20 Python
Django调用支付宝接口代码实例详解
2020/04/04 Python
在主流系统之上安装Pygame的方法
2020/05/20 Python
前端实现背景虚化但内容清晰且自适应 的实例代码
2019/08/01 HTML / CSS
Monnier Frères美国官网:法国知名奢侈品网站
2016/11/22 全球购物
飞利浦西班牙官方网站:Philips西班牙
2020/02/17 全球购物
美国在线购买空气净化器、除湿器、加湿器网站:AllergyBuyersClub
2021/03/16 全球购物
Java的五个基础面试题
2016/02/26 面试题
What's the difference between an interface and abstract class? (接口与抽象类有什么区别)
2012/10/29 面试题
通信生自我鉴定
2014/01/18 职场文书
地质灾害防治方案
2014/05/14 职场文书
大学生找工作求职信
2014/07/09 职场文书
pandas中DataFrame重置索引的几种方法
2021/05/24 Python
CSS 使用 resize 实现图片拖拽切换预览功能(强大功能)
2021/08/23 HTML / CSS
美国运营商 T-Mobile 以 117.83Mb/s 的速度排第一位
2022/04/21 数码科技