2022-06-04 分類: 網站建設
重繪:當頁面元素樣式的改變不影響布局時,瀏覽器重新對元素進行更新的過程叫做重繪。
重排:當頁面元素的尺寸、結構、或某些屬性發生改變時,瀏覽器重新渲染部分或全部文檔的過程叫做重排也叫做回流。
DOM:描述該頁面的結構
render:描述 DOM 節點 (nodes) 在頁面上如何呈現
當 DOM 元素的屬性發生變化 (如 color) 時, 瀏覽器會通知 render 重新描繪相應的元素, 此過程稱為 repaint。
如果該次變化涉及元素布局 (如 width), 瀏覽器則拋棄原有屬性, 重新計算并把結果傳遞給 render 以重新描繪頁面元素, 此過程稱為 reflow。
這兩個過程是很耗費瀏覽器性能的, 從 IE 系列和 Chrome 渲染頁面速度上的差距即可看出渲染引擎計算對應值和呈現并不一定高效, 而每次對元素的操作都會發生 repaints 或 reflow, 因此編寫 DOM 交互時如果不注意就會導致頁面性能低下
1.解析HTML代碼并生成一個 DOM 樹。
2.解析CSS文件,順序為:瀏覽器默認樣式->自定義樣式->頁面內的樣式。
3.生成一個渲染樹(render tree)。這個渲染樹和DOM樹的不同之處在于,它是受樣式影響的。它不包括那些不可見的節點。
4.當渲染樹生成之后,瀏覽器就會在屏幕上“畫”出所有渲染樹中的節點。
不管頁面發生了重繪還是重排,它們都會影響性能(最可怕的是重排 ,應盡量避免)
頁面初始渲染
添加/刪除可見DOM元素
改變元素位置
改變元素尺寸(寬、高、內外邊距、邊框等)
改變元素內容(文本或圖片等)
改變窗口尺寸
由于回流和重繪會帶來很大的性能開銷,所以在開發中我們要盡量避免或減少回流和重繪的次數來提高性能
1. 避免頻繁讀取會引發回流/重繪的屬性,如果確實需要多次使用,就用一個變量緩存起來。
2. 對具有復雜動畫的元素使用絕對定位,使其脫離文檔流,否則會引起父元素及后續元素頻繁回流。
3. 要避免頻繁的去操作DOM,可以通過創建documentFragment,完成所有所有DOM操作后,最后再把它添加到文檔中。
4. 避免頻繁操作樣式,最好一次性重寫style屬性,或者將樣式列表定義為class并一次性更改class屬性。
var curLeft=div.offsetLeft;
var curTop=div.offsetTop;
div.style.left=curLeft+1+’px’;
div.style.top=curTop+1+’px’;
重繪的性能開銷較低,重排的性能開銷較高;
回流(重排)一定會觸發重繪,而重繪不一定會回流(重排)
網頁題目:什么是重繪和重排,它們的區別是什么?
網站網址:http://vcdvsql.cn/news13/163313.html
成都網站建設公司_創新互聯,為您提供微信公眾號、網站排名、域名注冊、營銷型網站建設、建站公司、面包屑導航
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯
猜你還喜歡下面的內容