vue.js框架原理浅析

vue.js是一个很是优秀的前端开发框架,不是我说的,你们都知道。前端

首先我如今的能力,独立阅读源码仍是有很大压力的,所幸vue写的很规范,经过方法名基本能够略知一二,里面的原理不懂的地方多方面查找资料,本文中不规范不正确的地方欢迎指正,学生很是愿意接受各位前辈提出宝贵的建议和指导。vue

使用vue的版本是v2.5.13,采用了flow做为类型管理工具,关于flow相关内容选择性忽略了,不考虑类型系统,只考虑实现原理,写下这篇文章。node

本文大概涉及到vue几个核心的地方:vue实例化,虚拟DOM,模板编译过程,数据绑定。react

1、vue的生命周期

image

2、vue实例化

研究vue的实例化就要研究_init方法,此方法定义在src/core/instance/init.js下的initMixin中,里面是对vue实例即vm的处理。其中包括开发环境下的代理配置等一些列处理,并处理了传递给构造函数的参数等,重点在一系列方法web

initLifecycle(vm)
    initEvents(vm)
    initRender(vm)
    callHook(vm, 'beforeCreate')
    initInjections(vm) // resolve injections before data/props
    initState(vm)
    initProvide(vm) // resolve provide after data/props
    callHook(vm, 'created')

初始化生命周期,初始化事件,初始化渲染,触发执行beforeCreate生命周期方法,初始化data/props数据监听,触发执行created生命周期方法。算法

对应到生命周期示例图,created方法执行结束,接下来判断是否传入挂载的el节点,若是传入的话此时就会经过$mount函数把组件挂载到DOM上面,整个vue构造函数就执行完成了。以上是vue对象建立的基本流程。浏览器

3、模板编译

挂载的$mount函数,此函数的实现与运行环境有关,在此只看web中的实现。框架

实现只有简单的两行,dom

一、判断运行环境为浏览器,

二、调用工具方法查找到el对应的DOM节点,

三、mountComponent方法来实现挂载,

这里就涉及到了挂载以前的处理问题。ide

一、对于拥有render(JSX)函数的状况,组件能够直接挂载,

二、若是使用的是template,须要从中提取AST渲染方法(注意若是使用构建工具,最终会为咱们编译成render(JSX)形式,因此无需担忧性能问题),AST即抽象语法树,它是对真实DOM结构的映射,可执行,可编译,可以把每一个节点部分都编译成vnode,组成一个有对应层次结构的vnode对象。

有了渲染方法,下一步就是更新DOM,注意并非直接更新,而是经过vnode,因而涉及到了一个很是重要的概念。

4、虚拟dom

虚拟DOM技术是一个很流行的东西,现代前端开发框架vue和react都是基于虚拟DOM来实现的。

虚拟DOM技术是为了解决一个很重要的问题:浏览器进行DOM操做会带来较大的开销。

一、要知道js自己运行速度是很快的,

二、而js对象又能够很准确地描述出相似DOM的树形结构,

基于这两点前提,人们研究出一种方式,

经过使用js描述出一个假的DOM结构,每次数据变化时候,在假的DOM上分析数据变化先后结构差异,找出这个最小差异而且在真实DOM上只更新这个最小的变化内容,这样就极大程度上下降了对DOM的操做带来的性能开销。

上面的假的DOM结构就是虚拟DOM,比对的算法成为diff算法,这是实现虚拟DOM技术的关键。

一、在vue初始化时,首先用JS对象描述出DOM树的结构,

二、用这个描述树去构建真实DOM,并实际展示到页面中,

三、一旦有数据状态变动,须要从新构建一个新的JS的DOM树,

四、对比两棵树差异,找出最小更新内容,

五、并将最小差别内容更新到真实DOM上。

有了虚拟DOM,下面一个问题就是,何时会触发更新,接下来要介绍的,就是vue中最具特点的功能--数据响应系统及实现。

5、数据绑定

vue.js的做者尤雨溪老师在知乎上一个回答中提到过本身创做vue的过程,最初就是尝试实现一个相似angular1的东西,发现里面对于数据处理很是不优雅,因而创造性的尝试利用ES5中的Object.defineProperty来实现数据绑定,因而就有了最初的vue。vue中响应式的数据处理方式是一项颇有价值的东西。

vue官网上面其实有具体介绍,下面是一张官方图片:

image

vue响应

响应实现的基本原理:

一、vue会遍历此data中对象全部的属性,

二、并使用Object.defineProperty把这些属性所有转为getter/setter,

三、而每一个组件实例都有watcher对象,

四、它会在组件渲染的过程当中把属性记录为依赖,

五、以后当依赖项的 setter被调用时,会通知watcher从新计算,从而导致它关联的组件得以更新。

为何vue不能在IE8如下运行?

由于IE8不支持ES5,因此用不了Object.defineProperty方法,又由于Object.defineProperty没法shim,因此vue不支持IE8及如下不支持ES5的浏览器。

相关文章
相关标签/搜索