-
相信大家阅读过很多关于Vue2的文章,我也阅读过很多,但是大部分文章介绍的都是如何在项目中进行应用,技术点如果使用,功能如何实现;
-
今天小编为大家带来这篇Vue2的核心原理剖析就是为大家介绍我们常用的Vue2他是如何实现的核心内容,我们简单代码的背后究竟他做了哪些,让大家能够 知其然,知其所以然
学习目标:
-
了解Object.defineProperty原理
-
了解set、get关联使用
-
了解数据反应到识图的过程
-
了解视图更换如何影响数据
-
掌握MVVM
响应式的核心API
数据的变化可以引起视图的变化(通过操作dom把数据放到对应的位置上去 如果数据变化之后就用数据最新的值再重新放一次)
方案一:命令式操作
-
document.querySelector(’#app’).innerText = data.name
-
set函数中重新执行一下document.querySelector(’#app’).innerText = data.name
方案二:声明式渲染
v-text指令的实现
核心逻辑:通过‘模板编译’找到标记了v-text的元素,然后把对应的数据通过操作domapi放上去
1.通过app根元素找到所有的子节点 (元素节点,文本节点…) -> dom.nodeChilds
2.通过节点类型筛选出元素节点 (p) -> nodeType 1元素节点 3文本节点
3.通过v-text找到需要设置的具体的节点 <p v-text></p>
4.找到绑定了v-text标记的元素 拿到它身上所有的属性 id class v-text=“name”
5.通过v-text=“name” 拿到指令类型 ‘v-text’ 拿到需要绑定的数据的属性名 ‘name’
6.判断当前是v-text指令 然后通过操作domapi 把name属性对应的值放上去 node.innerText = data[name]
以上整个过程可以称作‘模板编译’
input元素 v-model双向绑定
M -> V
V -> M
M -> V
1.通过app根元素找到所有的子节点 (元素节点,文本节点…) -> dom.nodeChilds
2.通过节点类型筛选出元素节点 (p) -> nodeType 1元素节点 3文本节点
3.通过v-text找到需要设置的具体的节点 <p v-text></p>
4.找到绑定了v-text标记的元素 拿到它身上所有的属性 id class v-text=“name”
5.通过v-model=“name” 拿到指令类型 ‘v-model’ 拿到需要绑定的数据的属性名 ‘name’
6.判断当前是v-model指令 然后通过操作domapi 把name属性对应的值放上去 node.value = data[name]
v-model和v-text除了指令类型不一致,使用的dom api不一致 其它的步骤是完全一致的
V -> M
本质:事件监听在回调函数中拿到input中输入的最新的值然后赋值给绑定的属性
node.addEventListener('input',(e)=>{
data[name] = e.target.value
})
以上总结:
1.数据的响应式
2.数据变化影响视图
3.视图变化影响数据
4.指令是如何实现的(常规实现逻辑)
优化工作:
1.通用的数据响应式处理
data(){
return {
name:'cp',
age:28
}
}
基于现成的数据,然后都处理成响应式
Object.keys(data) // 由所有的对象的key组成的数组
Object.keys(data).forEach(key=>{
// key 属性名
// data[key] 属性值
// data 原对象
// 将所有的key都转成get和set的形式
defineReactive(data,key,data[key])
})
function defineReactive(data,key,value){
Oject.defineProperty(data, key, {
get(){
return value
},
set(newValue){
value = newValue
}
})
}
性能优化
1.webpack打包文件体积过大?(最终打包为一个js文件)
2.如何优化webpack构建的性能
3.移动端的性能优化
4.Vue的SPA 如何优化加载速度
5.移动端300ms延迟
6.页面的重构
所有的知识点都有详细的解答,我整理成了280页PDF《前端校招面试真题精编解析》。