关于浏览器渲染

CSS和JS在网页中的放置顺序是怎样的?

  • CSS的放置顺序:CSS放在head中,如果放在</body>标签的里面,那么当DOM树构建完成了,渲染树才构建。渲染树构建完成,浏览器不得不再重新渲染整个页面,这样造成了资源的浪费。如果放在<head> </head>之间,浏览器边构建边渲染(并发),页面加载效率高,用户体验也更好。

  • JS的放置顺序:JS放在body 标签内的最后。外链接用 <script src=""></script>,内部的用 <script></script>。普通的<script>标签的加载和解析都是同步的,会阻塞DOM的渲染,这也就是我们经常会把<script>写在<body>底部的原因之一,为了防止加载资源而导致的长时间的白屏,另一个原因是js可能会进行DOM操作,所以要在DOM全部渲染完后再执行。

解释白屏和FOUC。

  • 白屏
  1. 如果把样式放在底部,对于IE浏览器,在某些情景下(新窗口打开,刷新等)页面会出现白屏,而不是内容逐渐展现。
  2. 如果使用@import标签,即使CSS放入link,并且放在头部,也可能出现白屏。
  3. 对于图片和CSS, 在加载时会并发加载(如一个域名下同时加载两个文件)。 但在加载 JavaScript 时,会禁用并发,并且阻止其他内容的下载. 所以把 JavaScript 放入页面顶部也会导致白屏现象。
  • FOUC (Flash of Unstyled Content)

  • 如果把样式放在底部,对于IE浏览器,在某些场景下(点击链接,输入URL,使用书签进入等),会出现FOUC现象(逐步加载无样式的内容,等CSS加载完成后页面突然展现样式)。对于Firefox会一直表现出FOUC,这是由于Firefox内核 Gecko 渲染机制造成的。


    Mozilla's Gecko rendering engine main flow.png

async和defer的作用是什么?有什么区别?

  • 普通的<script>标签的加载和解析都是同步的,会阻塞DOM的渲染,这也就是我们经常会把<script>写在<body>底部的原因之一,为了防止加载资源而导致的长时间的白屏,另一个原因是js可能会进行DOM操作,所以要在DOM全部渲染完后再执行, 有什么方法可以防止这些问题的产生呢,就有了async (异步)和defer (延迟)。
  • async(异步),加载和渲染后续文档元素的过程将和 script.js 的加载与执行并行进行(异步)。
  • defer(延迟),加载后续文档元素的过程将和 script.js 的加载并行进行(异步),但 script.js 的执行要在所有元素解析完成之后,DOMContentLoaded 事件触发之前完成。
  • 遇上设有async属性的脚本,会在HTML解析过程中下载该脚本,并在完成下载后暂停HTML的解析来执行这个异步脚本,直到执行完成后再继续HTML的解析。打个比方,做饭的同时,也品尝自己做的菜,感觉味道很好了,才出锅,继续做下一道菜。
  • 遇上有defer属性的脚本,会在HTML解析过程中下载该脚本,在HTML解析完成后才执行该文件,延迟脚本按照它们在文档中出现的顺序执行。打个比方,做好饭后,才品尝自己做的菜,不管好不好吃,都已经出锅了。
  • async属性可以保证脚本下载的同时,浏览器进行渲染。需要注意的是,一旦采用这个属性就无法保证脚本的执行顺序。哪个脚本先下载结束,就先执行哪个脚本。

翻到一篇博客,讲解的不错,更多内容可以参考这篇博客 async和defer的作用和区别

简述网页的渲染机制

  • webkit内核渲染机制
  1. 解析html标签,构建dom树。
  2. 解析css标签,构建cssom树。
  3. 把dom和cssom组合成渲染树(render tree)。
  4. 在渲染树的基础上进行布局,计算每个节点的结构。
  5. 把每个节点绘制到屏幕上(painting)。
Webkit main flow.png
  • Gecko内核渲染机制
  1. 解析 HTML 标签到 Content Sink。
  2. 这时,先加载Content Sink 里面的内容,页面上会显示一个无样式的内容(HTML标签,网页内容优先)。
  3. 循环加载 CSS 样式, 构建渲染结构。
  4. 重新渲染页面, 绘制到屏幕上(painting)。
Mozilla's Gecko rendering engine main flow.png
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,390评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,821评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,632评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,170评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,033评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,098评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,511评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,204评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,479评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,572评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,341评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,893评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,171评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,486评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,676评论 2 335

推荐阅读更多精彩内容