资讯专栏INFORMATION COLUMN

Vuex源码学习(五)加工后的module

2bdenny / 1824人阅读

摘要:先看一下创建一个容器存放该模块所有的子模块存放自己未被加工的模块内容。是封装的工具方法,用于遍历对象的。这些方便高效的方法为之后的注册。

没有看过moduleCollection那可不行!Vuex源码学习(四)module与moduleCollection

代码块和截图的区别

代码块部分希望大家按照我的引导一行行认真的读

代码的截图是希望大家能记住图中的结构与方法,下面会对整体进行一个分析,而不会一行一行的分析。

但是以后的文章会更偏向于使用代码块,希望大家喜欢。

上一章我们讲述了ModuleCollection类的作用,帮助我们把伪(未加工的)模块变成真正的模块,然后把每个模块按照父子与兄弟关系链接起来。那么真正的模块相比于伪(未加工的)模块多了哪些能力呢?

module提供的方法


这是module暴露出来的所有方法,以及一个属性。

先看一下constructor
constructor (rawModule, runtime) {
    this.runtime = runtime
    // Store some children item
    // 创建一个容器存放该模块所有的子模块
    this._children = Object.create(null)
    // Store the origin module object which passed by programmer
    // 存放自己未被加工的模块内容。
    this._rawModule = rawModule
    const rawState = rawModule.state
    // Store the origin module‘s state
    // 创建这个模块的数据容器
    this.state = (typeof rawState === "function" ? rawState() rawState) || {}
}

模块的初始化主要是做了以下三件事情

创建_children属性用于存放子模块

创建_rawModule属性存储自己模块的伪(未被加工)模块时的内容

创建state属性存储自己模块的数据内容 每个模块都有自己的state。

模块的初始化并没有做什么事情,模块提供的方法和属性才是它的核心,
模块提供了一个namespaced的属性,以及很多方法,我将模块提供的方法分成两类。

先说属性
get namespaced () {
    // 获取模块的namespaced属性 确定这个模块有没有自己的命名空间
    return !!this._rawModule.namespaced
}

判断是否有命名空间有什么用?在以后设置getters、mutation、actions时有很大作用,以后再讲。

再说方法

模块提供的所有方法都是为了给外部的调用,这些方法没有一个是让模块在自己的内部使用的。所以我把方法划分的纬度是,按照这个方法是用于构建模块树还是用于抽取模块中的内容

构建模块树的方法:

1.addChild:给模块添加子模块。

addChild (key, module) {
    this._children[key] = module
}

这个方法实现上很简单,它是在哪里被调用的呢?大家可以翻开上一章的moduleCollection的内容,在ModuleCollection中完成模块之间的链接,就是使用这个方法给父模块添加子模块。

removeChild:移除子模块 Vuex初始化的时候未使用,但可以给你提供灵活的处理模块的能力

removeChild (key) {
    delete this._children[key]
}

getChild:获取子模块 获取子模块的意义是什么?在以后配置模块的名字时,需要获取模块的是否设置了命名空间,获取命名空间的属性模块提供了,再提供一个获取子模块就都Ok了

getChild (key) {
    return this._children[key]
}

updateChild:更新模块的_ra wModule属性(更新模块的未加工前的模块内容),Vuex中未使用

update (rawModule) {
    this._rawModule.namespaced = rawModule.namespaced
    if (rawModule.actions) {
      this._rawModule.actions = rawModule.actions
    }
    if (rawModule.mutations) {
      this._rawModule.mutations = rawModule.mutations
    }
    if (rawModule.getters) {
      this._rawModule.getters = rawModule.getters
    }
}

Vuex在链接与整合模块的时候使用了其中两个方法,addChild、getChild。类ModuleCollection在链接时需要找到模块(getChild)然后给模块添加子模块(addChild)的功能,所以这两个方法是在整合模块时最重要的。

抽取模块中的内容

上面的一组方法,是为了更好的完成模块的链接,给散落的单一模块整理成一个模块树可以提供便捷的封装方法,下面要说的方法什么叫做抽取模块中的内容?将这些方法暴露给外面可以方便的去获取这个模块内的一些内容来使用。


forEachValue是Vuex封装的工具方法,用于遍历对象的。

export function forEachValue (obj, fn) {
  Object.keys(obj).forEach(key => fn(obj[key], key))
}

这四个方法作用:

forEachChild : 遍历模块的子模块

forEachGetter : 遍历模块中_rawModule.getters 这块就应该知道 _rawModule的作用了,我把模块未加工时会有getters属性,存放这个模块所有的getters方法(vuex的基本用法就不多讲了),然后遍历,

forEachMutation : 和forEachGetter类似,只是换成了遍历mutations

forEachAction : 和forEachGetter类似,只是换成了遍历actions

这四个方法就是遍历这些内容,有意义吗?

意义很大,目前_rawModule上这些getters、mutations、actions属性并不会生效,只是单纯的一个属性,如何让他们可以成为那种,被dispatch、commit使用的那种方法呢?先给大家一个小提示,mutations、actions都是要被注册的,注册之前总要获取到这些内容,具体的实现方式后面的章节会详细讲述,

总结

加工后真正的module(我们称由Module这个类实例化出来为真正的module)只是缓存了一些内容,并且给外界提供了一堆方便高效的方法。这些方便高效的方法为之后的注册action、mutation。整合state都起了很关键的作用。所以说module这个小单元为下面的代码提供了很大便利,
额外思考我们对一段内容需要频繁的处理并且处理方式大同小异的时候,是不是可以像module一样整理成一个对象,然后给外界提供一些方法。(有一种面向对象思想)

下一章讲述action和mutation是如何调用的

我是一个应届生,最近和朋友们维护了一个公众号,内容是我们在从应届生过渡到开发这一路所踩过的坑,已经我们一步步学习的记录,如果感兴趣的朋友可以关注一下,一同加油~

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/103061.html

相关文章

  • vuex 2.0源码解读(一)

    摘要:简单点说,当你使用构造函数,它实际上做了这么几件事,首先定义给实例定义一些内部属性,之后就是绑定和的上下文对象永远是实例上,之后根据传入的充实内部状态等等。函数执行的结果是返回一个对象,属性名对应于传入的对象或者数组元素。 转载请注明出处 https://segmentfault.com/a/11... vuex2.0 和 vuex1.x 相比,API改变的还是很多的,但基本思想没什么...

    luqiuwen 评论0 收藏0
  • 手挽手带你学VUE:四档 Vue-cli3 Vuex Vue-router

    摘要:安装过后到命令行执行检查版本,如果弹出版本的话恭喜你安装成功,我们开始进行下面的步骤了。全局安装的包名称由改成了。如果你已经全局安装了旧版本的或,你需要先通过卸载它。中的非常类似于事件每个都有一个字符串的事件类型和一个回调函数。 视频教程 由于思否不支持视频外链,视频请移步http://www.henrongyi.top 你能学到什么 在这一期的学习进度中,我们会开始学习在我们工作开...

    Sourcelink 评论0 收藏0
  • 手挽手带你学VUE:四档 Vue-cli3 Vuex Vue-router

    摘要:安装过后到命令行执行检查版本,如果弹出版本的话恭喜你安装成功,我们开始进行下面的步骤了。全局安装的包名称由改成了。如果你已经全局安装了旧版本的或,你需要先通过卸载它。中的非常类似于事件每个都有一个字符串的事件类型和一个回调函数。 视频教程 由于思否不支持视频外链,视频请移步http://www.henrongyi.top 你能学到什么 在这一期的学习进度中,我们会开始学习在我们工作开...

    AlphaWallet 评论0 收藏0
  • 深入学习Vuex

    摘要:深入学习作为配合使用的数据状态管理库,针对解决兄弟组件或多层级组件共享数据状态的痛点问题来说,非常好用。至此,构造函数部分已经过了一遍了。 深入学习Vuex vuex作为配合vue使用的数据状态管理库,针对解决兄弟组件或多层级组件共享数据状态的痛点问题来说,非常好用。本文以使用者的角度,结合源码来学习vuex。其中也参考了许多前辈的文章,参见最后的Reference Vue加载Vuex...

    codercao 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<