快速上手vuex

作者: PengL | 来源:发表于2017-02-28 21:14 被阅读4032次

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

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

为什么要用vuex

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

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

Vuex的核心

vuex由以下几部分组成:

  • state
  • mutations
  • getters
  • actions
  • modules
  • state里面就是存放的我们上面所提到的状态
  • mutations就是存放如何更改状态
  • getters就是从state中派生出状态,比如将state中的某个状态进行过滤然后获取新的状态。
  • actions就是mutation的加强版,它可以通过commit mutations中的方法来改变状态,最重要的是它可以进行异步操作。
  • modules顾名思义,就是当用这个容器来装这些状态还是显得混乱的时候,我们就可以把容器分成几块,把状态和管理规则分类来装。这和我们创建js模块是一个目的,让代码结构更清晰。

如何理解Vuex

vuex核心概念有五个,试想当我们把所有的状态从各个组件抽出来,放入了state中(以下有实际代码示例,如果完全没有接触的同学也不必担心,这里主要是理解vuex管理状态的方式,代码内容并不重要)

state.png
某个时候,某个组件中,我们需要给state中的list添加一个数据,我们肯定得想办法去干成这件事。vuex中就规定了我们必须通过commit mutations中的方法来做这件事:
mutations.png
某个时间,某个组件我们需要获得list中字符串长度大于10的所有数据,vuex中允许我们通过getters来获取: getters.png

某个时间,某个组件需要我们需要在事件发生2秒后再向list中添加数据,这个时候我们必须用actions,还记得上面我们提到的吗,只有通过actions处理异步问题

actions.png
当代码量不断增多,这个容器的状态和Mutations,actions,getters都太多了时,我们可以把它们按自己的需求进行分类,分成几个module,每个module和上面一样由state,mutations,actions,getters组成
modules.png

使用Vuex

1.vuex是vue的插件,我们使用前需要先引入它,然后全局注册这个插件:


useVuex.png

2.在入口文件中引入 该store并注册它:这样我们就能通过this.$store来获得这个容器了:

main.png

3.最后你就可以尽情在你的store容器中添加状态,然后用mutations更改状态,actions来异步更改状态,getters来获得部分状态。modules来分块管理状态。

Tips:
1.对于vuex这个容器,它的代码结构也十分重要,它决定了你是否能高效管理状态。
2.使用过程中我个人偏向于在组件中通过dispatch容器中的actions 在actions中通过commit mutations来改变状态或者进行其他操作,因为actions更强大,便于以后的扩展
3.对于modules,根据实际情况,可以单独给部分组件创建modules,部分getters或actions单独写在一个js模块中
4.笔者对vuex的介绍就到此为止,看完本篇文章我希望能帮助大家对vuex有一个快速的认识和理解,更具体的用法还请查看vuex的官方文档
5.对文章有不同意见或想法,欢迎在评论留言

相关文章

  • vuex 快速上手

    一. 引用 引入Vuex(前提是已经用Vue脚手架工具构建好项目) 1.安装 2、新建一个store文件夹(这个不...

  • 快速上手Vuex

    学过Vue的伙伴们都知道在简单的场景下,父子组件的通信可以用Props完成,孩子组件与父组件之间可以emit(触发...

  • 快速上手vuex

    Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应...

  • Vuex快速上手

    Vuex快速上手 通俗的解释:是一种最好的非父子组件传值的一种方案。官方解释:Vuex是一个公共状态管理(公共的内...

  • vuex入门实例2

    vuex入门实例2 这章节我准备以requirejs模块化,讲解下如何快速上手vuex 源码地址 工程代码结构如下...

  • Vuex 快速入门上手教程

    一. 什么是Vuex? Vuex是一个专门为Vue.js应用程序开发的状态管理模式, 它采用集中式存储管理所有组件...

  • vuex 上手使用

    什么是vuex Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。 每一个 Vuex 应用的核心就是...

  • Vuex简单上手

    Vuex Vuex是Vue.js应用的状态管理模式目前开发项目中,主要用于保存组件状态,保证兄弟组件间的通信。 首...

  • Masonry介绍与使用实践:快速上手Autolayout

    Masonry介绍与使用实践:快速上手Autolayout Masonry介绍与使用实践:快速上手Autolayout

  • Vuex入门到上手

    一、前言 当我们的应用遇到多个组件共享状态时,会需要多个组件依赖于同一状态。传参的方法对于多层嵌套的组件将会非常繁...

网友评论

  • 8a57c7a196f5:简单几句话就讲明白了,很棒磅。
  • 5edea3b599ac:官网看的我一脸懵逼,看完你这个发现,简单的了解了每个部分的大致意思,不至于一点懵逼了。这种教程就适合我这种还没入门的小白,简单、粗暴、好理解。再去看官网就更容易了。
  • be07b41fc4b4:一通乱截图,也不说是那个文件的截图,写的基本没有啥实际帮助啊
  • today0507:又看了一遍:smiley:
  • today0507:写的很清晰
  • 0c03a4e7a0dd:清晰干脆,干货!
  • c5fc12ab1035:👍,提个意见,我觉得首先我们应该说明官方文档中两种特殊情况或者说,那些情况如果不使用vuex会导致我们代码脆弱的情况,再回头看vuex才具有实际意义,这点官方也说的不是很明确,会给新人误导
  • 70f33dfb5c84:很详细,加个真实的例子 就更好了
  • tony9527:把核心概念说的简单明了!
  • 0cb165bbd4f6:很棒棒哦,谢谢作者分享:clap:
  • HeartDream:getters中处理过的状态,不用return吗
    PengL:@HeartDream 需要return,demo里是我自己的错误。后面会修正。thank you
  • b58b5a93c2a5:简单明了,一看就懂。谢谢分享
  • 7e4336b58cd3:清晰易懂,赞

本文标题:快速上手vuex

本文链接:https://www.haomeiwen.com/subject/wmttgttx.html