瀏覽器渲染過程

參考:
瀏覽器加載雁竞、解析、渲染的過程

解析:
1. 瀏覽器會將HTML解析成一個DOM樹佩厚,DOM 樹的構(gòu)建過程是一個深度遍歷過程:當(dāng)前節(jié)點的所有子節(jié)點都構(gòu)建好后才會去構(gòu)建當(dāng)前節(jié)點的下一個兄弟節(jié)點砾隅。
2. 將CSS解析成 CSS Rule Tree 。
3. 根據(jù)DOM樹和CSSOM來構(gòu)造 Rendering Tree漆改。注意:Rendering Tree 渲染樹并不等同于 DOM 樹,因為一些像 Header 或 display:none 的東西就沒必要放在渲染樹中了。
4.有了Render Tree返吻,瀏覽器已經(jīng)能知道網(wǎng)頁中有哪些節(jié)點、各個節(jié)點的CSS定義以及他們的從屬關(guān)系乎婿。下一步操作稱之為Layout测僵,顧名思義就是計算出每個節(jié)點在屏幕中的位置。
5.再下一步就是繪制,即遍歷render樹捍靠,并使用UI后端層繪制每個節(jié)點沐旨。

HTML頁面加載和解析流程
1. 用戶輸入網(wǎng)址(假設(shè)是個html頁面,并且是第一次訪問)榨婆,瀏覽器向服務(wù)器發(fā)出請求磁携,服務(wù)器返回html文件;
2. 瀏覽器開始載入html代碼良风,發(fā)現(xiàn)<head>標(biāo)簽內(nèi)有一個<link>標(biāo)簽引用外部CSS文件谊迄;
3. 瀏覽器又發(fā)出CSS文件的請求,服務(wù)器返回這個CSS文件拖吼;
4. 瀏覽器繼續(xù)載入html中<body>部分的代碼鳞上,并且CSS文件已經(jīng)拿到手了,可以開始渲染頁面了吊档;
5. 瀏覽器在代碼中發(fā)現(xiàn)一個<img>標(biāo)簽引用了一張圖片篙议,向服務(wù)器發(fā)出請求。此時瀏覽器不會等到圖片下載完怠硼,而是繼續(xù)渲染后面的代碼鬼贱;
6. 服務(wù)器返回圖片文件,由于圖片占用了一定面積香璃,影響了后面段落的排布这难,因此瀏覽器需要回過頭來重新渲染這部分代碼;
7. 瀏覽器發(fā)現(xiàn)了一個包含一行Javascript代碼的<script>標(biāo)簽葡秒,趕快運行它姻乓;
8. Javascript腳本執(zhí)行了這條語句,它命令瀏覽器隱藏掉代碼中的某個<div> (style.display=”none”)眯牧。突然少了這么一個元素蹋岩,瀏覽器不得不重新渲染這部分代碼;
9. 終于等到了</html>的到來学少,瀏覽器淚流滿面……
10. 等等剪个,還沒完,用戶點了一下界面中的“換膚”按鈕版确,Javascript讓瀏覽器換了一下<link>標(biāo)簽的CSS路徑扣囊;
11. 瀏覽器召集了在座的各位<div><span><ul><li>們,“大伙兒收拾收拾行李绒疗,咱得重新來過……”侵歇,瀏覽器向服務(wù)器請求了新的CSS文件,重新渲染頁面吓蘑。

重排

如果該次變化涉及元素布局 (如 width), 瀏覽器則拋棄原有屬性, 重新計算并把結(jié)果傳遞給 render 以重新描繪頁面元素, 此過程稱為 reflow惕虑。

下列情況會發(fā)生重排:

  • 頁面初始渲染
  • 添加/刪除可見DOM元素
  • 改變元素位置
  • 改變元素尺寸(寬、高、內(nèi)外邊距枷遂、邊框等)
  • 改變元素內(nèi)容(文本或圖片等)
  • 改變窗口尺寸
重繪

當(dāng) DOM 元素的屬性發(fā)生變化 (如 color) 時, 瀏覽器會通知 render 重新描繪相應(yīng)的元素, 此過程稱為 repaint樱衷。

減少 reflow/repaint
  • 不要一條一條地修改 DOM 的樣式。與其這樣酒唉,還不如預(yù)先定義好 css 的 class矩桂,然后修改 DOM 的 className。
  • 不要把 DOM 結(jié)點的屬性值放在一個循環(huán)里當(dāng)成循環(huán)里的變量痪伦。
  • 為動畫的 HTML 元件使用 fixed 或 absoult 的 position侄榴,那么修改他們的 CSS 是不會 reflow 的。
  • 千萬不要使用 table 布局网沾。因為可能很小的一個小改動會造成整個 table 的重新布局癞蚕。
  • 能用css3實現(xiàn)的就用css3實現(xiàn)。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末辉哥,一起剝皮案震驚了整個濱河市桦山,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌醋旦,老刑警劉巖恒水,帶你破解...
    沈念sama閱讀 222,000評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異饲齐,居然都是意外死亡钉凌,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評論 3 399
  • 文/潘曉璐 我一進店門捂人,熙熙樓的掌柜王于貴愁眉苦臉地迎上來御雕,“玉大人,你說我怎么就攤上這事滥搭∷岣伲” “怎么了?”我有些...
    開封第一講書人閱讀 168,561評論 0 360
  • 文/不壞的土叔 我叫張陵论熙,是天一觀的道長福青。 經(jīng)常有香客問我摄狱,道長,這世上最難降的妖魔是什么媒役? 我笑而不...
    開封第一講書人閱讀 59,782評論 1 298
  • 正文 為了忘掉前任,我火速辦了婚禮酣衷,結(jié)果婚禮上交惯,老公的妹妹穿的比我還像新娘。我一直安慰自己席爽,他們只是感情好意荤,可當(dāng)我...
    茶點故事閱讀 68,798評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著只锻,像睡著了一般玖像。 火紅的嫁衣襯著肌膚如雪齐饮。 梳的紋絲不亂的頭發(fā)上捐寥,一...
    開封第一講書人閱讀 52,394評論 1 310
  • 那天祖驱,我揣著相機與錄音握恳,去河邊找鬼。 笑死捺僻,一個胖子當(dāng)著我的面吹牛乡洼,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播匕坯,決...
    沈念sama閱讀 40,952評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼醒颖!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起泞歉,我...
    開封第一講書人閱讀 39,852評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎腰耙,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體挺庞,經(jīng)...
    沈念sama閱讀 46,409評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,483評論 3 341
  • 正文 我和宋清朗相戀三年选侨,在試婚紗的時候發(fā)現(xiàn)自己被綠了掖鱼。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片援制。...
    茶點故事閱讀 40,615評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖晨仑,靈堂內(nèi)的尸體忽然破棺而出褐墅,到底是詐尸還是另有隱情,我是刑警寧澤妥凳,帶...
    沈念sama閱讀 36,303評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站逝钥,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏晌缘。R本人自食惡果不足惜齐莲,卻給世界環(huán)境...
    茶點故事閱讀 41,979評論 3 334
  • 文/蒙蒙 一磷箕、第九天 我趴在偏房一處隱蔽的房頂上張望选酗。 院中可真熱鬧岳枷,春花似錦芒填、人聲如沸空繁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,470評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽闷祥。三九已至傲诵,卻和暖如春凯砍,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背拴竹。 一陣腳步聲響...
    開封第一講書人閱讀 33,571評論 1 272
  • 我被黑心中介騙來泰國打工悟衩, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人栓拜。 一個月前我還...
    沈念sama閱讀 49,041評論 3 377
  • 正文 我出身青樓座泳,卻偏偏與公主長得像,于是被迫代替她去往敵國和親幕与。 傳聞我的和親對象是個殘疾皇子挑势,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,630評論 2 359

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