vue源码阅读(二)
一 一个实例
如果简单了解过些Vue的API的话,肯定会对一下这个特别熟悉,在上一篇里,分析了Vue的核心文件core的index.js构造vue函数执行的流程。
那么下边这个则是实例化构造函数,也就是开始使用了,不管是作为框架,还是作为插件,都需要new一下。

千呼万唤,我们把它请出来之后,发现点不同的东西,router、filter、store暂时先不表,但是这个#app是个啥东西?
翻篇回去,先看Vue的构造函数,this._init(options)是调用的第一个方法,包括传进来的参数options,不过在这之前,还判断了下调用Vue的是不是先new出来的。

二 从init方法到Vue初始化做的第一件事
根据注入的文件 找到了 init方法的文件
,它是在core/instance/init.js
完整的方法如下

一开始是定义了两个属性 _uid 和_isVue
其中_uid是当前实例的唯一id,而且是递增的实例id 保证不会重复,一般会自动分配,不建议操作,当然如果需要操作的话,可以手动分配
_isVue设置为true,避免监听对象时自身被监听
然后是判断是否定义_isComponent(),这里查了下注释和代码,is_Component = true是指内部的组件实例,而initInternalCompoent()函数是作者对组件内部实例化的优化,
一般我们写的代码都会走else的分支,也就是mergeOptions() 这个方法。

接下来就遇到了第一个比较重要的点,理解mergeOptions这个方法,他定义在工具类的options这个js文件夹下。
首先想到的是为什么要进行策略对象的合并,而且是init的第一步,简单的说,Vue在处理选项的时候,使用了这个策略对象把父子选项进行合并,并将最终的值赋值给实例下
的$options,更直白的说就是把vue实例上原有的属性和传入的option以及继承和构造的所有属性进行递归式的合并,确保一个vue实例是有一个$options.
先说下这个options,当我们new一个vue的实例时,可以传一些数据,比如上面new的函数那样,从前边看,vue的实例在实例化后会加载很多其他的东西,例如生命周期钩子、render函数等等。
而手动传入的这个对象,就叫做options,也是上面vm.$options中传入的第二个参数,关于vm.$options,是一个贯穿整个源码的属性,可以单独拆出来讲,但是为了文章的完整性,先简单说一下,不然后边的这个合并策略对象就会云里雾里。
这是mergeOptions()执行的流程


这函数涉及到了很多复杂的合并策略,包括钩子函数、props、methods、inject\computed、directives、filter、data,为了轻松的走完整个流程,这里不展开
更具体的流程如下:

三 一个嵌套的三元表达式
看这些复杂的合并代码有点脑壳疼,作者还特别秀的写了个嵌套的三元表达式,他长这样。

四
总结一下Vue的初始化:Vue的初始化主要就干了这么几件事:合并配置、初始化生命周期、初始化事件和渲染逻辑、初始化data做数据劫持,这种把不同的功能和逻辑部分
拆分成一个个单独的模块,使得Vue的核心加载过程一目了然,这种编程思想是十分值得借鉴的。
vue源码阅读(二)的更多相关文章
- Vue源码分析(二) : Vue实例挂载
Vue源码分析(二) : Vue实例挂载 author: @TiffanysBear 实例挂载主要是 $mount 方法的实现,在 src/platforms/web/entry-runtime-wi ...
- 手牵手,从零学习Vue源码 系列二(变化侦测篇)
系列文章: 手牵手,从零学习Vue源码 系列一(前言-目录篇) 手牵手,从零学习Vue源码 系列二(变化侦测篇) 陆续更新中... 预计八月中旬更新完毕. 1 概述 Vue最大的特点之一就是数据驱动视 ...
- Vue源码学习二 ———— Vue原型对象包装
Vue原型对象的包装 在Vue官网直接通过 script 标签导入的 Vue包是 umd模块的形式.在使用前都通过 new Vue({}).记录一下 Vue构造函数的包装. 在 src/core/in ...
- vue源码阅读(一)
版本:2.5.17-beta.0 核心模块(src/core):包括组件.全局API.vue实例.对象属性监测系统.公共方法.虚拟dom.配置等模块 src/core/index.js import ...
- Vue源码阅读一:说说vue.nextTick实现
用法: 在下次 DOM 更新循环结束之后执行延迟回调.在修改数据之后立即使用这个方法,获取更新后的 DOM. 疑惑: 怎么实现的延迟回调 原理: JavaScript语言的一大特点就是单线程,同一个时 ...
- xxl-job源码阅读二(服务端)
1.源码入口 xxl-job-admin是一个简单的springboot工程,简单翻看源码,可以很快发现XxlJobAdminConfig入口. @Override public void after ...
- Spring 源码阅读 二
程序入口: 接着上一篇博客中看完了在AnnotationConfigApplicationContext的构造函数中的register(annotatedClasses);将我们传递进来的主配置类添加 ...
- vue源码阅读笔记
1.yarn test [文件名] -t [name-of-spec(describe or test )] 直接运行yarn test,会测试所有测试文件:yarn test 后面只跟文件名的话会 ...
- Vue源码学习(二)$mount() 后的做的事(1)
Vue实例初始化完成后,启动加载($mount)模块数据. (一)Vue$3.protype.$mount 标红的函数 compileToFunctions 过于复杂,主要是生 ...
随机推荐
- JavaScript关于原型的相关内容
function Person () { } Person.prototype.name = 'Alan'; Person.prototype.age = 26; Person.prototype.j ...
- 安卓ImageButton圆角按钮设置
首先图片要做成圆角的,使用美图秀秀,这个不多说. 之后使用设置了圆角的按钮,效果有缺陷,按钮会有灰色的边角. 类似这样: 去掉的方法是将layout的 android:src="@draw ...
- 16.Oct Working Note
01 writing algorithm by assembly,but the bug... now,it runs normaly,but how to print the answer? suc ...
- UWP入门(四)--设置控件样式
原文:UWP入门(四)--设置控件样式 官方定义:可以使用 XAML 框架通过多种方式自定义应用的外观. 通过样式可以设置控件属性,并重复使用这些设置,以便保持多个控件具有一致的外观. 可分享至不同e ...
- winform picturebox设置布局样式
这里分背景图和直接显示的图片的布局 背景图的布局为BackgroundImageLayout设置为strecth即为自动拉伸 图片的布局为SizeMode 设置为StretchImage即自动拉伸
- 比快更快——微软LightGBM
LightGBM介绍 xgboost是一种优秀的boosting框架,但是在使用过程中,其训练耗时过长,内存占用比较大.微软在2016年推出了另外一种boosting框架--lightgbm,在不降低 ...
- 使用网盘(Dropbox/Google Drive)同步Git仓库
还在使用老掉牙的U盘搬运代码(文件)的方式,从一台机器上复制后,粘贴到另一台机器上?太Out了.使用Github 倒是一个非常不错的替代方法.但无论是基于什么理由都有可能不想把代码公开(毕竟Githu ...
- 判断一个窗口是否被挂起(发WM_NULL消息,或者调用IsHungAppWindow API进行测试)
判断一个窗口是否被挂起了(就是没有响应了),在多窗口编程了经常会用到,在给别的窗口发消息前,为了目的窗口能确定收到消息,常常在之前先检测窗口是否被挂起了,我们以前常用的方式的是使用下面的方法: // ...
- Qt的槽可以使用默认参数
引用自:http://www.ibm.com/developerworks/cn/linux/guitoolkit/qt/signal-slot/ 的一篇经典文章,是关于Qt的信号和槽的分析的.看年份 ...
- 判断本地系统目录下是否存在XML文件,如果不存在就创建一个XMl文件,若存在就在里面执行添加数据
这是我为项目中写的一个测试的例子, 假如,您需要这样一个xml文件, <?xml version="1.0" encoding="utf-8"?> ...