【VUE】Vue源码分析(七)

0. debug调试

	1). 调试的目的
			查找bug: 不断缩小可疑代码的范围
			查看程序的运行流程(用于熟悉新接手项目的代码)
		
	2). 如何开启调试模式
			添加debugger语句: 程序运行前     此方式用打包后才运行的项目
			添加()断点: 程序运行前或者过程中   此方式用运行源码js
		
	3). 如何进行调试操作
			resume: 恢复程序执行(可能执行完或者进入下一个断点处)
			step over: 单步跳转, 尝试执行完当前语句, 进入下一条(如果内部有断点, 自动进入内部断点处)
			step into: 跳入, 进入当前调用函数内部
			step out: 跳出, 一次性执行完当前函数后面所有语句,并出去
			deactivate breakpoints: 使所有断点暂时失效
			
			call stack: 显示是程序函数调用的过程
			scope: 当前执行环境对应的作用域中包含的变量数据
			breakpoints: 断点列表

1. 准备

	1.ES5: [].slice.call(lis): 将伪数组转换为真数组
				call能让一个函数或对象的方法成为任意指定对象的方法进行调用
	  ES6: Array.from(lis): 将伪数组转换为真数组
	2.node.nodeType: 得到节点类型
		1-元素节点  2-属性节点  3-文本节点
	3.Object.defineProperty(obj, propertyName, {}): 给对象添加/修改属性(指定描述符)
			configurable: true/false  是否可以重新define
			enumerable: true/false 是否可以枚举(for..in / keys())
			value: 指定初始值
			writable: true/false value是否可以修改存取(访问)描述符
			get: 函数, 用来得到当前属性值
			set: 函数, 用来监视当前属性值的变化
	4.Object.keys(obj): 得到对象自身可枚举的属性名的数组
	5.DocumentFragment: 文档碎片(高效批量更新多个节点)
	6.obj.hasOwnProperty(prop): 判断prop是否是obj自身的属性
		prop是一个属性名字符串

2. 数据代理(MVVM.js)

	1.通过一个对象代理对另一个对象中属性的操作(/)
	2.通过vm对象来代理data对象中所有属性的操作
  	3.好处: 更方便的操作data中的数据
  	4.基本实现流程
				1). 通过Object.defineProperty()给vm添加与data对象的属性对应的属性描述符
				2). 所有添加的属性都包含getter/setter
				3). 在getter/setter内部去操作data中对应的属性数据
    

3. 模板解析(compile.js)

    作用:实现界面的初始化显示
	1.模板解析的关键对象: compile对象
    2.模板解析的基本流程:
        1). 将el的所有子节点取出, 添加到一个新建的文档fragment对象中
        2). 对fragment中的所有层次子节点递归进行编译解析处理
                * 对插值文本节点进行解析
                * 对元素节点的指令属性进行解析
                        * 事件指令解析
                        * 一般指令解析
        3). 将解析后的fragment添加到el中显示
    3.解析插值语法节点: textNode.textContent = value
        1). 根据正则对象得到匹配出的表达式字符串: 子匹配/RegExp.$1
        2). 从data中取出表达式对应的属性值
        3). 将属性值设置为文本节点的textContent
    4.事件指令解析: elementNode.addEventListener('eventName', callback.bind(vm))
        1). 从指令名中取出事件名
        2). 根据指令属性值(表达式)从methods中得到对应的事件处理函数对象
        3). 给当前元素节点绑定指定事件名和回调函数的dom事件监听
        4). 指令解析完后, 移除此指令属性
    5.一般指令解析: elementNode.xxx = value
        1). 得到指令名和指令值(表达式)
        2). 从data中根据表达式得到对应的值
        3). 根据指令名确定需要操作元素节点的什么属性
            * v-text---textContent属性
            * v-html---innerHTML属性
            * v-class--className属性
        4). 将得到的表达式的值设置到对应的属性上
        5). 移除元素的指令属性

4. 数据劫持–>数据绑定

	1.数据绑定(model==>View):
		1). 一旦更新了data中的某个属性数据, 所有界面上直接使用或间接使用了此属性的节点都会更新(更新)
	2.数据劫持
				1). 数据劫持是vue中用来实现数据绑定的一种技术
				2). 基本思想: 通过Object.defineProperty()来监视data中所有属性(任意层次)数据的变化, 一旦变化就去更新界面
  	3.四个重要对象
				1). Observer
						* 用来对data所有属性数据进行劫持的构造函数
						* 给data中所有属性重新定义属性描述(get/set)
						* 为data中的每个属性创建对应的dep对象
				2). Dep(Depend)
						* data中的每个属性(所有层次)都对应一个dep对象
						* 创建的时机:
								* 在初始化define data中各个属性时创建对应的dep对象
								* 在data中的某个属性值被设置为新的对象时
						* 对象的结构
								{
									id, // 每个dep都有一个唯一的id
									subs //包含n个对应watcher的数组(subscribes的简写)
								}
						* subs属性说明
								* 当一个watcher被创建时, 内部会将当前watcher对象添加到对应的dep对象的subs中
								* 当此data属性的值发生改变时, 所有subs中的watcher都会收到更新的通知, 从而最终更新对应的									界面
				3). Compile
						* 用来解析模板页面的对象的构造函数(一个实例)
						* 利用compile对象解析模板页面
						* 每解析一个表达式(非事件指令)都会创建一个对应的watcher对象, 并建立watcher与dep的关系
						* complie与watcher关系: 一对多的关系
				4). Watcher
						* 模板中每个非事件指令或表达式都对应一个watcher对象
						* 监视当前表达式数据的变化
						* 创建的时机: 在初始化编译模板时
						* 对象的组成
								{
                                        vm,  //vm对象
                                        exp, //对应指令的表达式
                                        cb, //当表达式所对应的数据发生改变的回调函数
                                        value, //表达式当前的值
                                        depIds //表达式中各级属性所对应的dep对象的集合对象
                                                        //属性名为dep的id, 属性值为dep
								}
				5). 总结: dep与watcher的关系: 多对多
						* 一个data中的属性对应对应一个dep, 一个dep中可能包含多个watcher(模板中有多个表达式使用到了同一个							 属性)
						* 模板中一个非事件表达式对应一个watcher, 一个watcher中可能包含多个dep(一个表达式中包含了多个							  data属性 如a.b.c)
						* 数据绑定使用到2个核心技术
								* Object.defineProperty()
								* 订阅者-发布者

	4.双向数据绑定
		1). 双向数据绑定是建立在单向数据绑定(model==>View)的基础之上的
		2). 双向数据绑定的实现流程:
				* 在解析v-model指令时, 给当前元素添加input监听
				* 当input的value发生改变时, 将最新的值赋值给当前表达式所对应的data属性
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值