成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專(zhuān)欄INFORMATION COLUMN

JavaScript:回流(重排)與重繪

Jioby / 3505人閱讀

摘要:回流也被稱(chēng)為重排,其實(shí)從字面上來(lái)看,重排更容易讓人形象易懂即重新排版整個(gè)頁(yè)面。重繪當(dāng)頁(yè)面元素樣式改變不影響元素在文檔流中的位置時(shí)如,,,瀏覽器只會(huì)將新樣式賦予元素并進(jìn)行重新繪制操作。你真的了解回流和重繪嗎

簡(jiǎn)單先了解一下瀏覽器的渲染過(guò)程(圖片來(lái)自于網(wǎng)絡(luò))

瀏覽器生成渲染樹(shù)的過(guò)程(圖片來(lái)自于網(wǎng)絡(luò))

回流

回流當(dāng)render tree中的一部分或全部因?yàn)樵氐囊?guī)模尺寸、布局、隱藏等改變時(shí),瀏覽器重新渲染部分DOM或全部DOM的過(guò)程?;亓饕脖环Q(chēng)為重排,其實(shí)從字面上來(lái)看,重排更容易讓人形象易懂(即重新排版整個(gè)頁(yè)面)。

重繪

當(dāng)頁(yè)面元素樣式改變不影響元素在文檔流中的位置時(shí)(如background-color,border-color,visibility),瀏覽器只會(huì)將新樣式賦予元素并進(jìn)行重新繪制操作。

什么時(shí)候會(huì)觸發(fā)回流或重繪?

有大量的用戶(hù)行為以及潛在的DHTML改變會(huì)觸發(fā)回流。例如,改變?yōu)g覽器窗口的大小,使用一些JavaScript方法,包括計(jì)算樣式,對(duì)DOM進(jìn)行元素的添加或刪除,或是改變?cè)氐腸lass等。

添加或者刪除可見(jiàn)的DOM元素;
元素位置改變;
元素尺寸改變——邊距、填充、邊框、寬度和高度;
內(nèi)容變化,比如用戶(hù)在input框中輸入文字,文本或者圖片大小改變而引起的計(jì)算值寬度和高度改變;
頁(yè)面渲染初始化;
瀏覽器窗口尺寸改變,resize事件發(fā)生時(shí);
計(jì)算offsetWidth和offsetHeight屬性;
設(shè)置style屬性的值;
   

回流必將引起重繪,而重繪不一定會(huì)引起回流。

如何減少回流、重繪? 一、 CSS中避免回流、重繪

1.盡可能在DOM樹(shù)的最末端改變class
2.避免設(shè)置多層內(nèi)聯(lián)樣式
3.動(dòng)畫(huà)效果應(yīng)用到position屬性為absolute或fixed的元素上
4.避免使用table布局
5.使用css3硬件加速,可以讓transform、opacity、filters等動(dòng)畫(huà)效果不會(huì)引起回流重繪

二、 JS操作避免回流、重繪

1.避免使用JS一個(gè)樣式修改完接著改下一個(gè)樣式,最好一次性更改CSS樣式,或者將樣式列表定義為class的名稱(chēng)
2.避免頻繁操作DOM,使用文檔片段創(chuàng)建一個(gè)子樹(shù),然后再拷貝到文檔中
3.先隱藏元素,進(jìn)行修改后再顯示該元素,因?yàn)閐isplay:none上的DOM操作不會(huì)引發(fā)回流和重繪
4.避免循環(huán)讀取offsetLeft等屬性,在循環(huán)之前把它們存起來(lái)
5.對(duì)于復(fù)雜動(dòng)畫(huà)效果,使用絕對(duì)定位讓其脫離文檔流,否則會(huì)引起父元素及后續(xù)元素大量的回流

總結(jié):

回流在瀏覽器中屬于一種用戶(hù)主導(dǎo)的操作,所以知道如何去改進(jìn)回流時(shí)間以及知道各種文檔屬性(DOM節(jié)點(diǎn)深度,css的渲染效率,各種各樣的樣式改變)對(duì)回流時(shí)間的影響對(duì)于前端開(kāi)發(fā)來(lái)講是很有幫助的。有時(shí)即便是回流一個(gè)單一的元素,也可能要求它的父元素以及任何跟隨它的元素也產(chǎn)生回流。例如需要改變某個(gè)元素的背景,這就不涉及該元素的屬性,所以只發(fā)生重繪。

寫(xiě)這篇文章,也看了很多相關(guān)的blog和文章,這篇文章寫(xiě)得不是很具體只是大概的內(nèi)容。想深入了解的話(huà)可以看下面這篇文章,既有例子又有深度。
你真的了解回流和重繪嗎

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/109078.html

相關(guān)文章

  • 【前端工程師手冊(cè)】學(xué)習(xí)回流重繪(reflow和repaint)

    摘要:重繪元素做了一些不影響排版的改變,比如背景色下劃線等等,只需要重新繪制的過(guò)程,叫做重繪。顯然回流帶來(lái)的代價(jià)大于重繪,因?yàn)橹乩L僅僅是重新畫(huà)一遍元素而已,但是重繪是重新計(jì)算重新畫(huà)。不然這會(huì)導(dǎo)致大量地讀寫(xiě)這個(gè)結(jié)點(diǎn)的屬性。 瀏覽器的大概工作流程 以普通的HTML頁(yè)面為例: 解析HTML文檔,生成dom樹(shù) 解析css產(chǎn)生css規(guī)則樹(shù) 解析JavaScript,通過(guò)DOM-API來(lái)操作dom樹(shù)和...

    liuyix 評(píng)論0 收藏0
  • 【前端工程師手冊(cè)】學(xué)習(xí)回流重繪(reflow和repaint)

    摘要:重繪元素做了一些不影響排版的改變,比如背景色下劃線等等,只需要重新繪制的過(guò)程,叫做重繪。顯然回流帶來(lái)的代價(jià)大于重繪,因?yàn)橹乩L僅僅是重新畫(huà)一遍元素而已,但是重繪是重新計(jì)算重新畫(huà)。不然這會(huì)導(dǎo)致大量地讀寫(xiě)這個(gè)結(jié)點(diǎn)的屬性。 瀏覽器的大概工作流程 以普通的HTML頁(yè)面為例: 解析HTML文檔,生成dom樹(shù) 解析css產(chǎn)生css規(guī)則樹(shù) 解析JavaScript,通過(guò)DOM-API來(lái)操作dom樹(shù)和...

    fish 評(píng)論0 收藏0
  • 瀏覽器的回流重繪及其優(yōu)化方式

    摘要:何時(shí)發(fā)生有大量的用戶(hù)行為以及潛在的改變會(huì)觸發(fā)回流。這樣就會(huì)讓多次的回流重繪變成一次回流重繪。因?yàn)樯系牟僮鞑粫?huì)引發(fā)回流和重繪。參考文章回流與重繪性能讓變慢參考文章瀏覽器的重繪與重排 推薦了解的知識(shí):基本的HTML,基本的JavaScript,以及一些css工作原理方面的知識(shí) 瀏覽器的渲染原理 css的加載和解析不會(huì)阻塞html文檔的解析 css的解析會(huì)阻塞js的執(zhí)行,必須等到CSSOM...

    hearaway 評(píng)論0 收藏0
  • 一次性弄懂回流重繪

    摘要:所以由此來(lái)看重繪不一定導(dǎo)致回流,回流一定會(huì)導(dǎo)致重繪前面我們說(shuō)回流和重繪是會(huì)對(duì)進(jìn)行修改,會(huì)消耗性能,所以我們要盡可能減少回流和重繪的次數(shù)。瀏覽器自己也清楚,如果每次操作都即時(shí)地反饋一次回流或重繪,那么性能上來(lái)說(shuō)是扛不住的。 回流(Reflow)重繪(Repaint) 什么時(shí)候會(huì)觸發(fā)回流或重繪呢? 當(dāng)我們對(duì)dom 進(jìn)行修改當(dāng)時(shí)候會(huì)引發(fā)它外觀(樣式)上的改變時(shí),就會(huì)觸發(fā)回流或重繪。這個(gè)過(guò)程本...

    JerryWangSAP 評(píng)論0 收藏0
  • 前端性能優(yōu)化——回流重繪

    摘要:前言最近在研究,接著就研究回顧起回流與重繪了?;亓髋c重繪,好像大家都很熟悉的樣子,但是要具體來(lái)說(shuō)說(shuō),又說(shuō)不出什么來(lái)。注意回流必將引起重繪,而重繪不一定會(huì)引起回流。 前言 最近在研究virtual dom,接著就研究回顧起回流(reflow)與重繪(repaint)了。 回流與重繪,好像大家都很熟悉的樣子,但是要具體來(lái)說(shuō)說(shuō),又說(shuō)不出什么來(lái)。下面我是我稍做的整理: 瀏覽器渲染流程 在理解這...

    endiat 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<