国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

詳解瀏覽器渲染頁面過程

2019-11-19 17:40:27
字體:
供稿:網(wǎng)友

詳解瀏覽器渲染頁面過程

1.解析HTML文件,創(chuàng)建DOM樹

自上而下,遇到任何樣式(link、style)與腳本(script)都會阻塞(外部樣式不阻塞后續(xù)外部腳本的加載)。

2.解析CSS

優(yōu)先級:瀏覽器默認(rèn)設(shè)置<用戶設(shè)置<外部樣式<內(nèi)聯(lián)樣式<HTML中的style樣式;
特定級:id數(shù)*100+類或偽類數(shù)*10+tag名稱*1

3.將CSS與DOM合并,構(gòu)建渲染樹(renderingtree)

DOM樹與HTML一一對應(yīng),渲染樹會忽略諸如head、display:none的元素

4.布局和繪制,重繪(repaint)和重排(reflow)

重排:若渲染樹的一部分更新,且尺寸變化,就會發(fā)生重排;
重繪:部分節(jié)點(diǎn)需要更新,但不改變其他集合形狀。如改變某個元素的顏色,就會發(fā)生重繪。 

附:

1.重繪和重排何時會發(fā)生:

(1)增加或刪除DOM節(jié)點(diǎn);
(2)display:none(重排并重繪);visibility:hidden(重排);
(3)移動頁面中的元素;
(4)增加或修改樣式;
(5)用戶改變窗口大小,滾動頁面等。

2.如何減少重繪和重排以提升頁面性能:

(1)不要一個個修改屬性,應(yīng)通過一個class來修改

錯誤寫法:div.style.width="50px";div.style.top="60px";
正確寫法:div.className+=" modify";

(2)clone節(jié)點(diǎn),在副本中修改,然后直接替換當(dāng)前的節(jié)點(diǎn);
(3)若要頻繁獲取計算后的樣式,請暫存起來;
(4)降低受影響的節(jié)點(diǎn):在頁面頂部插入節(jié)點(diǎn)將影響后續(xù)所有節(jié)點(diǎn)。而絕對定位的元素改變會影響較少的元素;
(5)批量添加DOM:多個DOM插入或修改,應(yīng)組成一個長的字符串后一次性放入DOM。使用innerHTML永遠(yuǎn)比DOM操作快。(特別注意:innerHTML不會執(zhí)行字符串中的嵌入腳本,因此不會產(chǎn)生XSS漏洞)。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 上饶县| 星座| 尚义县| 南川市| 河源市| 定西市| 宿松县| 黄陵县| 万荣县| 恩施市| 内黄县| 绥滨县| 刚察县| 宁安市| 义乌市| 彩票| 封丘县| 安福县| 子长县| 垣曲县| 微博| 桂林市| 沂源县| 自贡市| 海伦市| 林芝县| 阿克苏市| 水富县| 达拉特旗| 镇雄县| 商水县| 武宣县| 永泰县| 尼木县| 克什克腾旗| 静安区| 成安县| 通渭县| 白城市| 达尔| 长岛县|