Vue源码之数据驱动(个人向)
#1.大致流程

# 2.具体流程
数据驱动
New VUE
Where:src/core/instance/index.js
Do:
1.使用Function实现Vue类
2.调用_init 初始化Vue
3.混入各种Mixin(暂不清晰)
Think:
各种框架无论多么如何追其本源还是由基础的JS生成的一个"类",而后在其原型上追加方法属性等。
this._init
Where:src/core/instance/init.js
Do:
1.合并配置,(另行分析)
2.初始化⽣命周期,(另行分析)
3.初始化事件中⼼,
4.初始化渲染,
5.初始化data、props、computed、watcher.......
Think:此步功能将各种不通的功能,集中初始化,条理清楚。
$mount()
mountComponent
(实例挂载)
Where:src/platform/web/runtime/index.js
Do:调用mountComponent方法
- Where:src/core/instance/lifecycle.js
- Do:
1.调用vm._render⽅法先⽣成虚拟Node。(重点方法)
2.再 实例化 ⼀个渲染Watcher,在它的回调函数中会调⽤ updateComponent⽅法,(响应式方面)
3。最终调⽤vm._update更新DOM。(重点方法)
Think:这个实例地挂载就是调用mountComponent方法将整个渲染⼯作完成。核心两部就是下面的_render与_upadte
vm_render
(生成Vnode'虚拟node')
Where:src/core/instance/render.js
Do:调用$createElement 生成返回Vnode
Virtual DOM 是⽤ VNode 这么⼀个 Class 去描述,它是定义在 src/core/vdom/vnode.js中的。
- Where: src/core/vdom/create-elemenet.js
Do:接受5个参数
1.context:表⽰VNode的上下⽂环境,它是Component类 型;
2.tag:表⽰标签,它可以是⼀个字符串,也可以是⼀个Component ;
3.data:表⽰VNode的数 据,它是⼀个 VNodeData类型,可以在flow/vnode.js 中找到它的定义;
4.children:表⽰当前VNode的⼦节点,它是任意类型的,它接下来需要被规范为标准的 VNode 数组;
5.normalizationType:表⽰⼦节点规范的类型,类型不同规范的⽅法也就不⼀样,它主要是参 考render函数是编译⽣成的还是⽤户⼿写的。1.children的规范化
将children变成了⼀个类型为VNode的Array如果是⼀个数组类型,
则递归调⽤ normalizeArrayChildren ; 如果是基础类型,
则通过 createTextVNode⽅法转换成 VNode 类型;
否则就已经是 VNode 类型了- VNode 的创建
Think:整个过程使用上述方法再辅助Vue自己定义的Vnode类进行遍历生成Vue所需要的虚拟的node树。接下来就是渲染的操作。
vm_update
(VNode渲染成真实DOM)
Where:src/core/instance/lifecycle.js
Do:(仅讨论初次渲染)
核心方法:_path
- Where:src/platforms/web/runtime/patch.j
Do:使用核心方法createPatchFunction最终返回了⼀个patch方法
它接收 4个参数,
oldVnode 表⽰旧的 VNode 节点,它也可以不存在或者是 ⼀个 DOM 对象; vnode 表⽰执⾏ _render 后返回的
VNode 的节点; hydrating 表⽰是否是服 务端渲染;
removeOnly 是给 transition-group ⽤的,之后会介绍。- 核心方法:createElm
通过虚拟节点创建真实的DOM并插⼊到它的⽗节点中
进而通过createChildren 递归调用createElm 遍历所有虚拟节点(深度优先)
接着再调⽤invokeCreateHooks⽅法执⾏所有的 create的钩⼦并把 vnode push到 insertedVnodeQueue (队列)中。
最后调用 insert⽅法把DOM插⼊到⽗节点中,也就是最基础的appendChild
先子后父 insert:src/core/vdom/patch.j
总结
1.通过简单的流程梳理,可以发现,再数据驱动实现过程中Vue整个框架也是一步步通过原型继承的方法将一个个方法实现执行。
2.所谓数据驱动也就是,将实际Dom使用核心方法(_render)和Vue自定义的Vnode类遍历处理生成Vnode,而后通过(_update)_path分类型遍历后推到一个队列中最后通过Insert 进行dom操作生成真是DOM。
后记
1.关于vue源码之前就根据网上资料看过,之前自己是手画了流程图,想想最后还是变成电子脑图好点。最后选择了Xmind。确实好用,画完了, 才发现还有直接生成MD文件的功能,那就直接发在博客上吧,全当正儿八经写点博客,哈哈,之前的笔记之类的,也希望慢慢能发到网上,
2.关于这文章,希望看到的你,能有点收获,如果那个地方有错希望指点交流,我也是个人走的过程,个人理解还是要一步步深入。
3.关于博客,只希望能够多个交流的机会吧,比较个人理解向的东西,仁者见仁。
Vue源码之数据驱动(个人向)的更多相关文章
- 大白话Vue源码系列(05):运行时鸟瞰图
阅读目录 Vue 实例的生命周期 实例创建 响应的数据绑定 挂载到 DOM 节点 结论 研究 runtime 一边 Vue 一边源码 初看 Vue 是 Vue 源码是源码 再看 Vue 不是 Vue ...
- 逐行剖析Vue源码(一)——写在最前面
1. 前言 博主作为一名前端开发,日常开发的技术栈是Vue,并且用Vue开发也有一年多了,对其用法也较为熟练了,但是对各种用法和各种api使用都是只知其然而不知其所以然,因此,有时候在排查bug的时候 ...
- Vue源码之组件化/生命周期(个人向)
大致流程 具体流程 组件化 (createComponent) 构造⼦类构造函数 const baseCtor = context.$options._base // plain options ob ...
- 手牵手,从零学习Vue源码 系列一(前言-目录篇)
系列文章: 手牵手,从零学习Vue源码 系列一(前言-目录篇) 手牵手,从零学习Vue源码 系列二(变化侦测篇) 手牵手,从零学习Vue源码 系列三(虚拟DOM篇) 陆续更新中... 预计八月中旬更新 ...
- 手牵手,从零学习Vue源码 系列二(变化侦测篇)
系列文章: 手牵手,从零学习Vue源码 系列一(前言-目录篇) 手牵手,从零学习Vue源码 系列二(变化侦测篇) 陆续更新中... 预计八月中旬更新完毕. 1 概述 Vue最大的特点之一就是数据驱动视 ...
- VUE 源码学习01 源码入口
VUE[version:2.4.1] Vue项目做了不少,最近在学习设计模式与Vue源码,记录一下自己的脚印!共勉!注:此处源码学习方式为先了解其大模块,从宏观再去到微观学习,以免一开始就研究细节然后 ...
- Vue源码后记-其余内置指令(3)
其实吧,写这些后记我才真正了解到vue源码的精髓,之前的跑源码跟闹着玩一样. go! 之前将AST转换成了render函数,跳出来后,由于仍是字符串,所以调用了makeFunction将其转换成了真正 ...
- Vue源码后记-钩子函数
vue源码的马拉松跑完了,可以放松一下写点小东西,其实源码讲20节都讲不完,跳了好多地方. 本人技术有限,无法跟大神一样,模拟vue手把手搭建一个MVVM框架,然后再分析原理,只能以门外汉的姿态简单过 ...
- 大白话Vue源码系列(01):万事开头难
阅读目录 Vue 的源码目录结构 预备知识 先捡软的捏 Angular 是 Google 亲儿子,React 是 Facebook 小正太,那咱为啥偏偏选择了 Vue 下手,一句话,Vue 是咱见过的 ...
随机推荐
- mint 18中安装最新的R
mint 中默认的R版本有点老,升级最新版方法如下: 先卸载 sudo apt-get remove r-base-core 添加mint 18 识别的源 sudo echo "deb ht ...
- Mac下Rblas配置
Mac 下加速 R做矩阵计算, 感觉比没有R open 快, 但数量级上差不多了. 安装R open时,提示 X11相关的组件缺失,不想再额外安装,怕污染系统文件. cd /Library/Frame ...
- 894A. QAQ#(暴力)
题目出处:http://codeforces.com/problemset/problem/894/A 题目大意:计数依次出现QAQ的次数 #include<iostream> using ...
- BZOJ2733 [HNOI2012]永无乡(并查集+线段树合并)
题目大意: 在$n$个带权点上维护两个操作: 1)在点$u,v$间连一条边: 2)询问点$u$所在联通块中权值第$k$小的点的编号,若该联通块中的点的数目小于$k$,则输出$-1$: 传送门 上周的模 ...
- Review For Exam
Review For Exam [2019 福建省赛] 一个很简单的状态压缩DP,结果集体走偏 如何解决连续几日的限制问题?这种东西普通的DP很难写 #include <bits/stdc++. ...
- Spring 的 IOC 和 AOP 的理解
Spring 的 IOC 和 AOP 的理解: https://www.jianshu.com/p/bf1adc3b75e6 对Spring的核心(AOP和IOC)的理解(大白话) https://w ...
- android简洁饼状图组件、圆形Menu菜单、画板画笔应用、答题应用等源码
Android精选源码 android自动监听复制内容源码 Android上简洁轻量级的饼图控件 好看的 Android 圆形 Menu 菜单效果 android画笔.画板功能效果的实现 Androi ...
- ionic3 修改页面切换动画
在app.module.ts中 配置pageTransition属性 [ BrowserModule, IonicModule.forRoot(MyApp, { pageTransition: 'io ...
- VMware 安装 Centos7 后,没有ipv4的地址,或者地址显示127.0.0.1
问题描述:VMware 安装 Centos7 后,没有ipv4的地址,或者地址显示127.0.0.1 安装环境:VMware版本:VMware-workstation-full-14.0.0.2405 ...
- day48-线程-信号量
#1.信号量,用来保证多个线程不会互相冲突. #2.迷你唱吧:每次只能有两人在里面唱k: from threading import Thread from threading import Sema ...