淺談瀏覽器渲染機制

眾所周知,瀏覽器是世界上用途最廣泛的軟件了弊决,它們展現(xiàn)著網(wǎng)絡資源仅政,但達成這個目標的過程是復雜并且遵循著很多不同的標準。里面的運行機制是具有迷惑性和反常規(guī)的静汤,理解瀏覽器的運行機制給了我們提升網(wǎng)絡性能和網(wǎng)絡應用效率的洞察力琅催。
接下來,就讓我們來簡單認識下瀏覽器渲染的基本原理虫给。

一藤抡、首先,讓我們認識幾個基本概念

  • DOM:(Document Object Model)抹估,瀏覽器將HTML解析成樹形的數(shù)據(jù)結構缠黍,簡稱DOM。DOM 是文檔對象模型 (Document Object Model) 的縮寫药蜻。它是 HTML 文檔的對象表示瓷式,同時也是外部內(nèi)容(例如 JavaScript)與 HTML 元素之間的接口。 解析樹的根節(jié)點是Document對象语泽。
  • CSSOM:(CSS Object Model)贸典,瀏覽器將CSS代碼解析成樹形的數(shù)據(jù)結構。
  • 渲染引擎 :渲染引擎就是在瀏覽器的屏幕上顯示請求的內(nèi)容湿弦。
    默認情況下瓤漏,呈現(xiàn)引擎可顯示 HTML 和 XML 文檔與圖片。通過插件(或瀏覽器擴展程序)颊埃,還可以顯示其他類型的內(nèi)容蔬充;例如,使用 PDF 查看器插件就能顯示 PDF 文檔班利。但是在本章中饥漫,我們將集中介紹其主要用途:顯示使用 CSS 格式化的 HTML 內(nèi)容和圖片。Firefox罗标、Chrome和Safari是基于兩種渲染引擎構建的庸队,F(xiàn)irefox使用Geoko——Mozilla自主研發(fā)的渲染引擎,Safari和Chrome都使用webkit闯割。Webkit是一款開源渲染引擎彻消,它本來是為Linux平臺研發(fā)的,后來由Apple移植到Mac及Windows上

二宙拉、渲染的主流程

渲染引擎首先通過網(wǎng)絡獲得所請求文檔的內(nèi)容宾尚,通常以8K分塊的方式完成。
下面是渲染引擎在取得內(nèi)容之后的基本流程:
1. 解析html為dom樹,解析css為cssom煌贴。
渲染引擎開始解析html御板,并將標簽轉(zhuǎn)化為內(nèi)容樹中的dom節(jié)點。
2. 把dom和cssom結合起來生成渲染樹(render)
接著牛郑,它解析外部CSS文件及style標簽中的樣式信息怠肋。這些樣式信息以及html中的可見性指令將被用來構建另一棵樹——render樹。Render樹由一些包含有顏色和大小等屬性的矩形組成淹朋,它們將被按照正確的順序顯示到屏幕上笙各。
3. 布局渲染樹,計算幾何形狀
Render樹構建好了之后瑞你,將會執(zhí)行布局過程酪惭,它將確定每個節(jié)點在屏幕上的確切坐標。
4. 把渲染樹展示到屏幕上
再下一步就是繪制者甲,即遍歷render樹春感,并使用UI后端層繪制每個節(jié)點。

  解析html以構建dom樹 -> 構建render樹 -> 布局render樹 -> 繪制render樹
2011110316263715.png
render-tree-construction.png

優(yōu)化這個嚴格的過程讓我們可以以最快的速度向用戶展示我們的網(wǎng)頁內(nèi)容虏缸。
值得注意的是鲫懒,關鍵的點在于上述的4個過程并不是以嚴格順序執(zhí)行的。渲染引擎會以最快的速度展示內(nèi)容刽辙,所以第二階段不會等到第一階段結束才開始窥岩,而是在第一階段有輸出的時候就開始執(zhí)行。其它階段也是如此宰缤。由于瀏覽器會嘗試盡快展示內(nèi)容颂翼,所以內(nèi)容有時會在樣式還沒有加載的時候展示出來。
這就是經(jīng)常發(fā)生的FOCU(flash of unstyled content)或白屏問題慨灭。

主流程示例

webkitflow.png

圖:WebKit 主流程

image008.jpg

圖:Mozilla 的 Gecko 呈現(xiàn)引擎主流程

從上圖我們可以看出朦乏,雖然 WebKit 和 Gecko 使用的術語略有不同,但整體流程是基本相同的氧骤。
Gecko 將視覺格式化元素組成的樹稱為“框架樹”呻疹。每個元素都是一個框架。WebKit 使用的術語是“呈現(xiàn)樹”筹陵,它由“呈現(xiàn)對象”組成刽锤。對于元素的放置,WebKit 使用的術語是“布局”朦佩,而 Gecko 稱之為“重排”并思。對于連接 DOM 節(jié)點和可視化信息從而創(chuàng)建呈現(xiàn)樹的過程,WebKit 使用的術語是“附加”语稠。有一個細微的非語義差別纺荧,就是 Gecko 在 HTML 與 DOM 樹之間還有一個稱為“內(nèi)容模塊(Content Model)”的層,用于生成 DOM 元素.

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市宙暇,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌议泵,老刑警劉巖占贫,帶你破解...
    沈念sama閱讀 207,248評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異先口,居然都是意外死亡型奥,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評論 2 381
  • 文/潘曉璐 我一進店門碉京,熙熙樓的掌柜王于貴愁眉苦臉地迎上來厢汹,“玉大人,你說我怎么就攤上這事谐宙√淘幔” “怎么了?”我有些...
    開封第一講書人閱讀 153,443評論 0 344
  • 文/不壞的土叔 我叫張陵凡蜻,是天一觀的道長搭综。 經(jīng)常有香客問我,道長划栓,這世上最難降的妖魔是什么兑巾? 我笑而不...
    開封第一講書人閱讀 55,475評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮忠荞,結果婚禮上蒋歌,老公的妹妹穿的比我還像新娘。我一直安慰自己委煤,他們只是感情好堂油,可當我...
    茶點故事閱讀 64,458評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著素标,像睡著了一般称诗。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上头遭,一...
    開封第一講書人閱讀 49,185評論 1 284
  • 那天寓免,我揣著相機與錄音,去河邊找鬼计维。 笑死袜香,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的鲫惶。 我是一名探鬼主播蜈首,決...
    沈念sama閱讀 38,451評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了欢策?” 一聲冷哼從身側響起吆寨,我...
    開封第一講書人閱讀 37,112評論 0 261
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎踩寇,沒想到半個月后啄清,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,609評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡俺孙,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,083評論 2 325
  • 正文 我和宋清朗相戀三年辣卒,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片睛榄。...
    茶點故事閱讀 38,163評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡荣茫,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出场靴,到底是詐尸還是另有隱情啡莉,我是刑警寧澤,帶...
    沈念sama閱讀 33,803評論 4 323
  • 正文 年R本政府宣布憎乙,位于F島的核電站票罐,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏泞边。R本人自食惡果不足惜该押,卻給世界環(huán)境...
    茶點故事閱讀 39,357評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望阵谚。 院中可真熱鬧蚕礼,春花似錦、人聲如沸梢什。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽嗡午。三九已至囤躁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間荔睹,已是汗流浹背狸演。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留僻他,地道東北人宵距。 一個月前我還...
    沈念sama閱讀 45,636評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像吨拗,于是被迫代替她去往敵國和親满哪。 傳聞我的和親對象是個殘疾皇子婿斥,可洞房花燭夜當晚...
    茶點故事閱讀 42,925評論 2 344

推薦閱讀更多精彩內(nèi)容