亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

回流和重涂之間有什么區別?

回流和重涂之間有什么區別?

當年話下 2019-12-13 10:24:49
我對重排和重繪之間的區別還不清楚(如果有任何區別)好像重排可能正在轉移各種DOM元素的位置,其中重畫只是呈現一個新對象。例如,在移除元素時將發生回流,而在更改其顏色時將發生重新繪制。這是真的?
查看完整描述

3 回答

?
牛魔王的故事

TA貢獻1830條經驗 獲得超3個贊

DOM布局發生更改時,就會發生重排?;亓髟谟嬎闵戏浅0嘿F,因為必須再次計算頁面元素的尺寸和位置,然后才能重新繪制屏幕。


可能導致回流的示例


for (let i = 1; i <= 100; i++ {

const newEle = document.createElement('p');

newEle.textContent = 'newly created paragraph element';


document.body.appendChild(newEle);

}

上面的代碼效率很低,每個附加的新段落元素都會導致100個重排過程。


您可以使用以下方法緩解此計算壓力大的過程 .createDocumentFragment()


const docFrag = document.createDocumentFragment();


 for (let i = 1; i <= 100; i++ {

    const newEle = document.createElement('p');

    newEle.textContent = 'newly created paragraph element';


    docFrag.appendChild(newEle);

    }


document.body.appendChild(docFrag);

上面的代碼現在將只使用重排過程1x來創建100個新的段落元素。


重繪只是監視器上像素的變化,同時還要加重它的兩個弊端,因為重排在其過程中包括重繪。


查看完整回答
反對 回復 2019-12-13
  • 3 回答
  • 0 關注
  • 734 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號