50万奖金+官方证书,深圳国际金融科技大赛正式启动,点击报名 了解详情
写点什么

一道浏览器面试题,就能看出你的前端功底

  • 2019-08-15
  • 本文字数:1240 字

    阅读完需:约 4 分钟

一道浏览器面试题,就能看出你的前端功底

作为前端工程师,几乎每天都要和浏览器打交道。


理解浏览器是如何工作的,对我们做业务的技术选型、架构设计等都有非常重要的作用,让我们可以准确评估 Web 开发项目的可行性,站在更高维度审视页面,以及在快节奏的技术迭代中把握住问题的本质。


可是我发现,大部分前端工程师对浏览器的理解,其实并不深入透彻。


比如,面试时我通常会问候选者一个问题:“在浏览器里,从输入 URL 到页面展示中间发生了什么? ”


这道题涉及到网络、操作系统、Web 等一系列的知识,如果你要开发流畅的页面,或者诊断 Web 页面中的性能问题,那你就需要了解 URL 是怎么变成页面的,只有弄懂这些之后,你才可以站在全局的角度定位问题或者写出高效的代码。


但遗憾的是,大多数人只能回答其中零散的知识点,并不能将这些知识点串联成线,无法系统全面地回答。


也难怪,浏览器确实会涉及很多概念,不仅繁多而且琐碎,包括网络、渲染、安全,以及大前端相关的大量概念。比如,首屏的显示就涉及了 DNS、HTTP、DOM 解析、CSS 阻塞、JavaScript 阻塞等技术因素,其中一项没处理好就可能导致整个页面的延时。如果没有系统的学习,很容易出现遗漏和盲点。


所以,我推荐大家看看极客时间的专栏《浏览器工作原理与实践》


作者是前盛大创新院高级研究员李兵。08 年的时候,他就基于 Chromium 和 IE 发布了一款双核浏览器:太阳花。这是国内第一款双核浏览器,你在使用它的时候,除了能享受到 Chrome 的快捷之外,还能兼容只支持 IE 的站点。可能现在的你不觉得有多厉害,但在当时,简直是前端的爆炸新闻。这款浏览器,在没有任何宣传的情况下,日活达到了 20 多万。


之后李兵去了盛大创新院,参与研发 WebOS 项目,基于 WebKit 内核打造一个能和安卓并存的操作系统。


后来,他又到了顺网科技,和团队打造了一款给全国网吧使用的“F1 浏览器”,日启量达到 2000 万。大家都知道,网吧的电脑环境异常复杂,页面劫持经常发生,再加上每天千万级别的启动量,对页面安全、加载速度和流畅度都有很高的要求。


可以说,这些经历,让李兵在浏览器核心技术上,有独到理解和独家经验。


因此,他来写浏览器相关的专栏,也一定与众不同,更具实操性。据他说,在《浏览器工作原理与实践》专栏里,想带你重新认识浏览器,把网络、页面渲染、JavaScript、浏览器安全等知识串联起来,从而让你对整个前端体系有全新的认识。


再送你一张李兵制作的知识框架图,让你对浏览器所覆盖所有知识点有所认知。


李兵是如何讲解浏览器的?

专栏分为 7 大模块,共 35 篇文章,覆盖 JavaScript 执行机制、引擎 V8 的工作原理、Web 页面中的事件循环系统、HTTP/1、HTTP/2 和 HTTP/3 的介绍、以及最近比较火的 PWA 的工作原理等内容。


最吸引我的,是李兵会自己绘制原理图和流程图,用通俗易懂的语言,图文并茂的展现形式,带你层层深入浏览器,看懂前端本质。


比如,下面是“渲染流水线的总结图”



线程之间共享进程中的数据示意图:



下面是专栏的详细目录:



《浏览器工作原理与实践》限时订阅福利


戳我订阅,早鸟优惠¥68,原价¥99


优惠最后 2 天


2019-08-15 15:073488

评论

发布
暂无评论
发现更多内容

再解 JavaScript 原型 与原型链

编程三昧

JavaScript 前端 原型 原型链 2月月更

精度丢失问题

编程三昧

2月月更

浅析 Python 中的 Collections 模块

宇宙之一粟

Python 2月月更

JVM进阶(一):初识 JAVA 栈

No Silver Bullet

Java JVM 2月月更

也谈一下Web3.0-01

wood

300天创作 Web3.0

如何写好代码注释?

蜜糖的代码注释

Java 后端 开发 2月月更

ReactNative进阶(四十五):渐变组件 react-native-linear-gradient

No Silver Bullet

React Native 2月月更

原型与原型链

编程三昧

JavaScript 前端 1月月更

【拥有新时代的通信协议,引领云原生迈向更高的舞台】解密Dubbo3从微服务升华到云原生 | 社区征文

码界西柚

云原生 Cloud Native Dubbo3 新春征文 2月月更

怎样设计一个广告系统

俞凡

架构 大厂实践 2月月更

Netflix是如何做决策的? | 3. A/B测试结果之假阳性和统计显著性

俞凡

数据分析 netflix 大厂实践 2月月更

共赴冰雪之约,见证体育场馆的数字化之旅

脑极体

使用 React、Solidity 和 Web3.js 构建真实世界的 dApp

devpoint

dapp React Solidity Web3.0 2月月更

以太坊剖析 - 交易执行(TransactionExecutor)

起航

区块链 以太坊

ReactNative进阶(五十一): 常见样式梳理

No Silver Bullet

CSS ReactNative 2月月更

【以太坊剖析】以太坊虚拟机(EVM)之基本定义

起航

区块链 以太坊 EVM 以太坊虚拟机

Netflix是如何做决策的? | 2. 什么是A/B测试

俞凡

数据分析 netflix 大厂实践 2月月更

ReactNative进阶(四十七):移动端调试利器 vConsole

No Silver Bullet

ReactNative 2月月更 vconsole

ReactNative进阶(四十八):Mobile App 适配性优化实战

No Silver Bullet

适配 ReactNative 2月月更

Firefox 登录后无法同步书签

TroyLiu

firefox 工具 浏览器 数据同步 书签

《卡片笔记写作法》读书笔记 - 重新认知思考和写作

懒时小窝

读书感悟 读书总结

【技术】谈ServiceMesh落地的三大难题:选型、过渡、多集群

极光一号。

云原生 servicemesh 服务网格 应用交付

以太坊剖析 - 区块头部(BlockHeader)

起航

区块链 以太坊

MySQL架构设计

JavaEdge

2月月更

JDK9响应式流使用详解

蜜糖的代码注释

Java Java9 2月月更 响应式流

以太坊剖析 - 区块(Block)

起航

区块链 以太坊

Netflix是如何做决策的? | 1. Netflix的决策制定

俞凡

数据分析 netflix 大厂实践 2月月更

ReactNative进阶(五十):IOS 系统 Crash 日志分析实战

No Silver Bullet

ios React Native 2月月更

以太坊剖析 - 交易收据(TransactionReceipt)

起航

区块链 以太坊

(2-1/26) 滑雪的准备

mtfelix

300天创作

WebRTC 如何在安卓系统上采集视频数据 | 社区征文

liuzhen007

音视频 新春征文 2月月更

一道浏览器面试题,就能看出你的前端功底_大前端_李兵_InfoQ精选文章