麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 網站 > 網頁設計 > 正文

頁面重構應注意的repaint和reflow

2024-08-30 08:36:25
字體:
來源:轉載
供稿:網友

我們一起來學習一下頁面重構應注意的repaint和reflow,首先了解一下什么是repaint和reflow。

1. 什么是 repaint 和 reflow?

一個頁面由兩部分組成:
DOM:描述該頁面的結構
render:描述 DOM 節點 (nodes) 在頁面上如何呈現

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

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

這兩個過程是很耗費瀏覽器性能的, 從 IE 系列和 Chrome 渲染頁面速度上的差距即可看出渲染引擎計算對應值和呈現并不一定高效, 而每次對元素的操作都會發生 repaints 或 reflow, 因此編寫 DOM 交互時如果不注意就會導致頁面性能低下.
頁面渲染的過程如下:

頁面重構應注意的repaint和reflow

1.解析HTML代碼并生成一個 DOM 樹。

2.解析CSS文件,順序為:瀏覽器默認樣式->自定義樣式->頁面內的樣式。

3.生成一個渲染樹(render tree)。這個渲染樹和DOM樹的不同之處在于,它是受樣式影響的。它不包括那些不可見的節點。

4.當渲染樹生成之后,瀏覽器就會在屏幕上“畫”出所有渲染樹中的節點。

2. 什么情況下會觸發瀏覽器的repaint/reflow?

除了頁面在首次加載時必然要經歷該過程之外,還有以下行為會觸發這個行為:
引用:
1. DOM元素的添加、修改(內容)、刪除( Reflow + Repaint)
2. 僅修改DOM元素的字體顏色(只有Repaint,因為不需要調整布局)
3. 應用新的樣式或者修改任何影響元素外觀的屬性
4. Resize瀏覽器窗口、滾動頁面
5. 讀取元素的某些屬性(offsetLeft、offsetTop、offsetHeight、offsetWidth、 scrollTop/Left/Width/Height、clientTop/Left/Width/Height、 getComputedStyle()、currentStyle(in IE))
3. 怎么優化?

1. 避免在document上直接進行頻繁的DOM操作,如果確實需要可以采用off-document的方式進行,具體的方法包括但不完全包括以下幾種:


引用:
1. 先將元素從document中刪除,完成修改后再把元素放回原來的位置
2. 將元素的display設置為”none”,完成修改后再把display修改為原來的值
3. 如果需要創建多個DOM節點,可以使用DocumentFragment創建完后一次性的加入document
2. 集中修改樣式


引用:
       1. 盡可能少的修改元素style上的屬性
       2. 盡量通過修改className來修改樣式
       3. 通過cssText屬性來設置樣式值
3. 緩存Layout屬性值


引用:
       對于Layout屬性中非引用類型的值(數字型),如果需要多次訪問則可以在一次訪問時先存儲到局部變量中,之后都使用局部變量,這樣可以避免每次讀取屬性時造成瀏覽器的渲染。
4. 設置元素的position為absolute或fixed


引用:
       在元素的position為static和relative時,元素處于DOM樹結構當中,當對元素的某個操作需要重新渲染時,瀏覽器會渲染整個頁 面。將元素的position設置為absolute和fixed可以使元素從DOM樹結構中脫離出來獨立的存在,而瀏覽器在需要渲染時只需要渲染該元素 以及位于該元素下方的元素,從而在某種程度上縮短瀏覽器渲染時間,這在當今越來越多的Javascript動畫方面尤其值得考慮。
5. 權衡速度的平滑


引用:
       比如實現一個動畫,以1個像素為單位移動這樣最平滑,但reflow就會過于頻繁,CPU很快就會被完全占用。如果以3個像素為單位移動就會好很多。
6. 不要用tables布局


引用:
       不要用tables布局的另一個原因就是tables中某個元素一旦觸發reflow就會導致table里所有的其它元素 reflow。在適合用table的場合,可以設置table-layout為auto或fixed,這樣可以讓table一行一行的渲染,這種做法也是為了限制reflow的影響范圍
7. 不要在css里面寫expression


引用:
       很多情況下都會觸發reflow,如果css里有expression,每次都會重新計算一遍

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 91色一区二区三区 | 日本高清在线播放 | 欧美爱爱视频免费看 | 免费永久在线观看黄网 | 92看片淫黄大片欧美看国产片 | japanesexxxx24videofree | 久久精品一区二区三区四区五区 | 91久久夜色精品国产网站 | 久久久久久久国产a∨ | 成片免费大全 | 一区二区三区黄色 | av手机免费在线观看 | 午夜精品久久久久久中宇 | 91精品国产一区二区三区四区在线 | 精品一区二区免费 | 亚洲精品久久久久久久久久久 | 美女污污在线观看 | 国产精品99爱 | 免费一级毛片免费播放 | 精品一二三区视频 | 国产精品片一区二区三区 | 中文字幕在线观看免费视频 | 欧美大荫蒂xxx| 欧美videofree性欧美另类 | h视频免费在线观看 | 色视频在线 | 久久国产精品99国产 | 国产精品片一区二区三区 | 欧美中文日韩 | 91 免费视频 | 在线成人亚洲 | 在线成人一区二区 | 亚洲国产精品一区二区精品 | 国产视频在线一区 | 亚洲一级毛片 | 国产精品久久久久一区二区 | 麻豆一二区 | 日本va在线观看 | 最新亚洲视频 | 精品亚洲夜色av98在线观看 | 黄色免费av |