教你阅读vue源码的正确姿势,看完就学废!,学web开发技术

  • 依赖分析组装:路由、父子组件层级

  • 模版编译:解析成AST语法树,进而构建虚拟dom树

  • 装载页面:虚拟dom整体转化为真实dom

  • 局部更新:响应式数据监控到变化,diff比较数据变化前后的虚拟dom树差异,局部更新dom

  • 销毁:销毁虚拟dom,移除dom

三、vue源码导读


  • template风格、对象配置风格

  • 虚拟dom思想(js对象操作代替dom操作)

  • diff算法思想(同层比较,添加、移动、删除)

  • 组件化思想(组件编译、组件通信)

  • 数据响应式(依赖收集、派发更新,发布订阅)

四、vue3新特性了解


vue2.x的痛点:

  • 源码自身的维护性;

  • 数据量大后带来的渲染和更新的性能问题;

  • 一些想舍弃但为了兼容一直保留的鸡肋 API 等;

  • TypeScript 支持;

vue3.0优化点:

  • 一、使用 monorepo管理源码

  • 二、使用 TypeScript 开发源码

  • 三、性能优化 1.源码体积优化 2.数据劫持优化Proxy 3.编译优化 4.diff算法优化

  • 四、语法 API 优化:Composition API

插一个题外话,小编整理了下用 Vue 3.0 来写个小程序框架的PDF资料,感兴趣的小伙伴们请点击这里领取

五、细究一下diff算法


vue2的diff

组件更新核心是响应式数据监控到数据的改变,重新生成了虚拟dom树,然后通过diff算法计算出前后虚拟dom树的差异点,更新dom时只更新变化的部分。 快问快答:

1. 为什么要diff?

答: O(n^3) 意味着如果要展示1000个节点,就要依次执行上十亿次的比较,无法承受大数据量的对比。

直接比较和修改两个树的复杂度为什么是n^3?

答: 老树的每一个节点都去遍历新树的节点,直到找到新树对应的节点。那么这个流程就是 O(n^2),再紧接着找到不同之后,再计算最短修改距离然后修改节点,这里是 O(n^3)。

2. diff的策略是什么?有什么根据?

答: 1、Web UI 中 DOM 节点跨层级的移动操作特别少,可以忽略不计,因此仅进行同层比较。 2、如果父节点不同,放弃对子节点的比较,直接删除旧节点然后添加新的节点重新渲染; 3、如果子节点有变化,Virtual DOM不会计算变化的是什么,而是重新渲染。 4、同级多个节点可通过唯一的key对比异同;

3. diff流程是什么?

答: 新旧节点不同:创建新节点 ➜ 更新父占位符节点 ➜ 删除旧节点; 新旧节点相同且没有子节点:不变; 新旧节点相同且都有子节点:遍历子节点同级比较,做移动、添加、删除三个操作,具体见下图;

vue3.0的diff

深度递归遍历vnode树,节点的标签和key相同认为是同一个节点则更新,不同则删除,然后处理子节点。 子节点分这几种情况处理:纯文本、vnode 数组和空

空往往意味着添加或删除; 纯文本相同直接更新innerText,不同则删除; 新旧子节点都是vnode数组则diff算法来处理;

vue3.0 diff算法思想

  • 编译模版时进行静态分析,标记动态节点,diff对比差异时仅对比动态节点(性能提升明显);

  • diff算法先去头去尾,借此缩短遍历对比数组长度(对数组插入和删除操作性能优化明显);

  • 通过对更新前后子节点数组建立映射表的方式,将O(n^2)复杂度的遍历降低到O(n);

  • 通过最长递增子序列方法了来diff前后的子节点数组,减少移动操作的次数;

最长递增子序列算法实现

/*

  • 寻找最长递增子序列

  • 使用动态规划思想,a -> c = a -> b + b -> c

  • 其中p数组存储的是从p[p[i]] 到 p[i] 的最长递增子序列索引,也就是前一个b的索引;

  • r数组存储最后一个元素也就是c的索引

*/

function getSequenceOfLIS(arr) {

const p = [0];

const result = [0];

for (let i = 0; i < arr.length; i ++) {

const val = arr[i];

const top = result[result.length - 1];

if (arr[top] < val) {

p[i] = top;

result.push(i);

continue;

}

// 二分法搜索

let l = 0, r = result.length - 1;

while(l < r) {

const c = (l + r) >> 1;

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

今天的文章可谓是积蓄了我这几年来的应聘和面试经历总结出来的经验,干货满满呀!如果你能够一直坚持看到这儿,那么首先我还是十分佩服你的毅力的。不过光是看完而不去付出行动,或者直接进入你的收藏夹里吃灰,那么我写这篇文章就没多大意义了。所以看完之后,还是多多行动起来吧!

可以非常负责地说,如果你能够坚持把我上面列举的内容都一个不拉地看完并且全部消化为自己的知识的话,那么你就至少已经达到了中级开发工程师以上的水平,进入大厂技术这块是基本没有什么问题的了。

章可谓是积蓄了我这几年来的应聘和面试经历总结出来的经验,干货满满呀!如果你能够一直坚持看到这儿,那么首先我还是十分佩服你的毅力的。不过光是看完而不去付出行动,或者直接进入你的收藏夹里吃灰,那么我写这篇文章就没多大意义了。所以看完之后,还是多多行动起来吧!

可以非常负责地说,如果你能够坚持把我上面列举的内容都一个不拉地看完并且全部消化为自己的知识的话,那么你就至少已经达到了中级开发工程师以上的水平,进入大厂技术这块是基本没有什么问题的了。

资料领取方式:戳这里前往免费领取

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript是一种流行的编程语言,被广泛用于网页开发。Vue.js是一个基于JavaScript前端开发框架,它提供了一套简洁、灵活的工具,使得开发者可以更轻松地构建交互式的Web应用程序。 Vue.js具有以下特点: 1. 渐进式:Vue.js采用渐进式的设计,可以逐步引入到现有的项目中,也可以通过逐步习来适应各种开发需求。 2. 轻量级:Vue.js的核心库只有约21KB,加载速度快,非常适合于移动端开发。 3. 组件化:Vue.js支持组件化的开发方式,开发者可以根据需要构建复用性高、可维护性好的组件,提高开发效率。 4. 响应式:Vue.js采用了响应式的设计,当数据发生变化时,对应的页面会自动更新,大大减少了处理DOM操作的工作。 5. 单文件组件:Vue.js支持单文件组件的开发方式,将HTML、CSS、JS代码封装在同一个文件中,提高了代码的可读性和可维护性。 一个使用Vue.jsWeb开发案例程可能包含以下内容: 1. 环境搭建:介绍如何安装配置开发Vue.js的环境,如Node.js和Vue CLI。 2. 基础语法:引导习者了解Vue.js的基本语法和常用指令,如数据绑定、事件处理、条件渲染等。 3. 组件开发:讲解如何使用Vue.js构建组件,如何进行组件通信、数据传递等。 4. 路由管理:介绍Vue Router,帮助习者构建单页应用程序,实现页面之间的切换和导航。 5. 状态管理:介绍Vuex,帮助习者管理应用程序的状态,实现数据的集中管理和共享。 6. 前后端交互:介绍如何使用Axios等工具,与后端服务器进行数据交互。 7. 实战项目:引导习者完成一个完整的Vue.js项目,如博客系统、电子商务网站等。 通过这样的案例程,习者可以逐步了解和掌握Vue.js的开发思想和技术,提高自己的Web开发能力。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值