You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

109 lines
12 KiB
Markdown

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

# 开篇词 | 参透了浏览器的工作原理你就能解决80%的前端难题
你好,我是李兵,现在是一名创业者,也是一名工程师。
我是2005年开始工作的基于对新技术的兴趣与敏感性2008年Chromium项目一开源我便第一时间下载体验。随后在创业阶段的我基于Chromium和IE发布了一款双核浏览器太阳花。
这是国内第一款双核浏览器使用它除了能享受到Chrome的快捷之外还能兼容只支持IE的站点。开发过程中最大的挑战是如何在Chromium中集成IE模块为此我花了大量时间来研究Chromium的进程架构以及渲染流程好在功夫不负有心人最终发布的产品也很对得起我的努力在没有任何宣传的情况下日活达到了20多万。
在2011年我就去了盛大创新院参与研发WebOS项目。WebOS的愿景是基于WebKit内核打造一个能和安卓并存的操作系统。我在团队中负责HTML5特性的实现比如实现Web Workers、Application Cache、LocalStorage、IndexedDB、CSS3部分动画效果等。这些工作经历让我对浏览器的整个渲染流程以及HTML5的发展趋势有了更加深入的认知。不过遗憾的是这个项目没能最终上线。
再之后我去了顺网科技。顺网科技是一家网吧服务提供商在顺网我和团队打造了一款给全国网吧使用的“F1浏览器”日启量达到2000万。由于网吧的电脑环境异常复杂页面劫持经常发生所以对页面安全提出来更高的要求再加上每天千万级别的启动量所以页面的加载速度和流畅度也至关重要它们直接决定了用户的流失程度。这段工作经历让我对浏览器安全有了全新的理解同时又对页面性能的优化有了系统性的认知。
算下来,我已经处在这个领域从业十余年,这过程中我踩过不少坑,也积累了不少经验,成长很多。从今天起,我会借此机会将我的工作经验分享给你,希望能对你的工作或生活有所帮助,让你学有所得、学有所用。
## 对于应用,浏览器的地位一直很重要
1995年美国网景公司因“网景浏览器”的发布而快速崛起之后网景试图开发一个依靠浏览器的网络操作系统。这引起了微软的注意和警惕于是同年微软发布Windows 95并捆绑了IE大获成功到2002年微软就已经占据了浏览器市场80%的份额。
直到2008年Chrome浏览器横空出世这种垄断局面才算被打破。Chrome浏览器完全颠覆了之前浏览器的架构设计在速度和安全性上占据了绝对优势市场份额占比剧增据 StatCounter 2019年的统计数据显示Chrome占据了63%市场份额。在2010年底Google还推出了一款网络操作系统——ChromeOS。
可以看到,浏览器自诞生之日起,其地位就一直很重要,而且这种重要性还在不断加强。我从浏览器的发展历程中梳理出了**三个大的进化路线希望能让你了解目前的Web应用到底能做什么以及未来能适用于那些新领域**。
**第一个是应用程序Web化**。随着云计算的普及和HTML5技术的快速发展越来越多的应用转向了浏览器/服务器B/S架构这种改变让浏览器的重要性与日俱增视频、音频、游戏几大核心场景也都在往Web的使用场景切换。
**第二个是Web应用移动化**。对于移动设备应用Web天生具有开放的基因虽然在技术层面还有问题尚待解决比如渲染流程过于复杂且性能不及原生应用、离线时用户无法使用、无法接收消息推送、移动端没有一级入口但Google推出了PWA方案来整合Web和本地程序各自的优势。顺便说一句PWA也是我个人非常期待的方案。
**第三个是Web操作系统化**。在我看来Web操作系统有两层含义一是利用Web技术构建一个纯粹的操作系统如ChromeOS二是浏览器的底层结构往操作系统架构方向发展在整个架构演化的大背景下会牵涉诸多改变下面列举一些我认为相对重要的改变。
* Chrome朝着SOA的方向演化未来很多模块都会以服务的形式提供给上层应用使用
* 在浏览器中引入多种编程语言的支持比如新支持的WebAssembly
* 简化渲染流程,使得渲染过程更加直接高效;
* 加大对系统设备特性的支持;
* 提供对复杂Web项目开发的支持。
也就是说,**浏览器已经逐步演化成了操作系统之上的“操作系统”**。
## 为什么需要学习浏览器工作原理?
前面我站在大厂的视角,带你回顾了浏览器的发展历程,梳理了浏览器的进化路线,分析了浏览器发展的大趋势。那接下来,我们再一起看看,开发者为什么需要了解浏览器的工作原理。
### 1\. 准确评估Web开发项目的可行性
随着Web特性的极大丰富和浏览器性能的提升越来越多的项目可以用Web来开发。所以了解浏览器是如何工作的能够让你更加准确地决策是否可以采用Web来开发项目。
举个例子去年我做了一个健身房虚拟教练项目时间紧任务重其中有大量的高速渲染动画和快速交互的场景需求。如果采用传统的C++来开发界面那基本上不可能按时交付而且后期的维护也会非常麻烦。于是我决定采用Web方案来开发界面因为采用Web方案可以降低开发成本缩短交付周期。最终利用这个方案我实现了这个项目的提前交付并且效果也很喜人大家对实现的效果非常满意。
对于这个例子,我认为我所做的最正确的事就是**选对了方案**但反过来想如果我对浏览器和HTML5的内容不了解那可能我很容易就放弃了这个最优方案。
### 2\. 从更高维度审视页面
作为一名合格的开发者,你还要具备一项重要的技能,那就是:**要能站在用户体验角度来考虑页面性能**。我们看下面几个常见的用户体验指标。
* 当用户请求一个网站时如果在1秒内看不到关键内容用户会产生任务被中断的感觉。
* 当用户点击某些按钮时如果100ms内无法响应用户会感受到延迟。
* 如果Web中的动画没有达到60fps用户会感受到动画的卡顿。
这里的页面加载时长、用户交互反馈时长、Web动画中的帧数都决定了用户体验的流畅度并最终决定了用户体验的效果。在用户体验尤其重要的今天我们必须能够有效地解决这些体验问题以免给产品造成不可挽回的伤害。
但通常这些指标是由一系列的复杂因素导致的。如果你要开发流畅的页面或者诊断Web页面中的性能问题那你就需要了解URL是怎么变成页面的只有弄懂这些之后你才可以站在全局的角度定位问题或者写出高效的代码。
你当然可以把浏览器看成一个黑盒左边输入一个URL经过黑盒处理之后右边返回你预期的效果。如果你对黑盒一无所知你倒依然可以写前端代码也可以使用很多最佳实践的策略来优化代码这就如同不了解操作系统的工作原理同样可以在操作系统上写应用一样。
但如果你理解了这个黑盒子是如何工作的那情况就不同了。你可以站在更高的维度审视你的项目通过全视野快速定位项目中不合理的地方。比如首屏的显示就涉及了DNS、HTTP、DOM解析、CSS阻塞、JavaScript阻塞等技术因素其中一项没处理好就可能导致整个页面的延时。
而如果你了解了浏览器的工作原理,更加可以把这些知识点串成线,连成网,最终形成自己的知识体系,练就像专家一样思考问题、解决问题的能力。
### 3\. 在快节奏的技术迭代中把握本质
从2011年到现在前端技术出现了大爆炸式增长各种新技术层出不穷。我认为**Node.js是前端发展的一个核心推动力**。Node.js是基于Chrome的JavaScript引擎V8来实现的它的特点是可以脱离浏览器环境来执行JavaScript于是大家惊讶地发现原来也可以使用JavaScript写服务器程序呀
尽管Node.js的诞生时间不长但其周边已经形成了一个庞大的生态系统。与此同时各种新标准、新技术纷至沓来前端生态空前繁荣。
为什么Node.js能如此快速地发展根本原因还是浏览器功能以及整个前端的开发环境不足以支撑日益增长的需求所以“变化”是这段时期的主旋律。这种变化直接扩大了前端工程师的知识半径**这也导致很多前端开发工程师变成了爆栈工程师**。
虽然前端技术变化快,不过我觉得这里有更大的机遇,谁能快速抓住变化,谁就能收获这波变化带来的红利。
我相信,随着脚本执行效率的提高、页面渲染性能的提升和开发工具链的完善,接下来的前端会进入一个相对平稳的阶段。通俗地理解就是:**等到核心技术足以支撑核心需求,那么前端生态会进入一个相对稳定的状态**。
如果了解了浏览器的工作机制,那么你可以梳理出来前端技术的发展脉络,更加深刻地理解当前的技术,同时你也会清楚其不足之处,以及演化方向。那么接下来,我们看看前端技术是如何针对这些核心诉求做演进的?
**首先是脚本执行速度问题**。比如针对JavaScript设计缺陷和执行效率的问题可以从以下两个途径去解决
* 不断修订和更新语言本身这样你就应该知道ES6、ES7、ES8或者TypeScript出现的必要性。这种修订对目前生态环境的改动是最小的所以推行起来会比较容易。
* 颠覆性地使用新的语言这就是WebAssembly出现的原因。WebAssembly需要经过编译器编译所以体积小、执行速度快使用它能大幅提升语言的执行效率但是语言本身的完善和生态的构建都是需要花很长时间来打造的。
**其次是前端模块化开发**。比如随着Web应用在各个领域的深入Web工程的复杂程度也越来越高这就产生了模块化开发的需求于是相应出现了WebComponents标准。我们所熟悉的React和Vue都在渐进地适应WebComponents标准同时各种前端框架的最佳实践也会反过来影响WebComponents标准的制定。
如果理解了浏览器工作原理那么你会对WebComponents中涉及的Shadow DOM、HTML Templates等技术有更深刻的理解。
**最后是渲染效率问题**。同样如果理解浏览器的渲染流程那么你应该知道目前页面的渲染依然存在很大缺陷然后你就清楚如何避开这些问题从而开发出更加高效的Web应用。与此同时Chrome团队也在着手改善这些缺陷比如正在开发的下一代布局方案LayoutNG还有渲染瘦身方案Slim Paint其目的都是让渲染变得更加简单和高效。
综上可以看出,触发这些改变的背后因素是当前技术制约了现实的需求,所以**了解浏览器是如何工作的,能让你站在更高维度去理解前端**。
## 专栏内容
所以,我希望通过这个专栏的学习,能让你系统地掌握浏览器工作原理,并把理论应用到前端实践。
下面就是这个专栏的目录,通过它你可以快速了解下这个专栏的知识体系结构。
![](https://static001.geekbang.org/resource/image/9b/92/9ba059d108b7e84479f2e57d90280892.jpg)
## 总结
我希望通过这个专栏的学习能让你重新认识浏览器并把网络、页面渲染、JavaScript、浏览器安全等知识串联起来从而让你对整个前端体系有全新的认识。同时我会保证用最简单通俗的语言把复杂的问题讲清楚这也意味着我会在本专栏上花更多时间所以也希望你能和我一起加油高质量学完本专栏。
最后我给你留个思考题吧:**你认为现代的前端工程师需要具备哪些核心的基础技能呢?**
欢迎你把你的想法写到留言区,我们一起来交流和探讨,共同进步。