reflow(回流)和repaint(重繪)

在瀏覽器渲染頁面的過程中爪瓜,頁面中的代碼進行渲染時,已經使瀏覽器不堪重負了匙瘪,如果當用戶使用時铆铆,替換一個背景顏色,或者更換一個樣式丹喻,那么我們的瀏覽器又需要重新加載代碼薄货,而在這個過程中,瀏覽器又一次的受到了壓力碍论,日復一日說不定哪天就崩掉了谅猾。 而主要影響頁面渲染速度的為:reflow和repaint

1.reflow(回流)

為什么頁面加載會慢,因為瀏覽器需要花時間鳍悠、花精力去渲染税娜,尤其是當它發(fā)現(xiàn)某個部分發(fā)生變化時影響到布局,就需要倒回去重新渲染藏研,這個’倒回去渲染的過程‘就叫做reflow(回流)

2.repaint(重繪)

如果變化的元素敬矩,只是更改了元素的背景色,文字顏色蠢挡、邊框顏色等等不影響它周圍或者內部布局的屬性弧岳,那這種行為只會引起repaint(重繪),所以repaint的速度明顯比reflow快

3.盡量減少reflow

1.reflow是導致DOM腳本執(zhí)行力較低的關鍵因素之一业踏,頁面上任何一個結點觸發(fā)reflow禽炬,都會導致它全部節(jié)點重新渲染。以下情況會導致reflow發(fā)生:

1.改變窗口大小
2.改變文字大小
3.添加/刪除樣式
4.內容的改變堡称,如用戶在輸入框進行輸入文字
5.激活偽類瞎抛,如hover艺演,active等
6.操作class屬性
7.腳本操作DOM
8.計算offsetWidth或者offsetHeight
9.設置style屬性

2.reflow是不可避免的却紧,只能將reflow對性能的影響見到最小:

  • 盡可能限制reflow的影響范圍胎撤,需要改變元素的樣式晓殊,不要通過父級元素影響子元素,最好直接加在子元素上伤提。
  • 通過設置style屬性改變節(jié)點樣式的話巫俺,每設置一次都會導致一次reflow。所以最好通過設置class的方式進行改變肿男。

3.該如何好的避免reflow

  • 實現(xiàn)元素的動畫介汹,將定位position設為fixed或者absolute却嗡,就不會影響其他元素的布局。
  • 權衡速度的平滑嘹承,比如實現(xiàn)一個動畫窗价,以1像素為單位移動最平滑,但是reflow會頻繁回流叹卷,我們可以進行節(jié)流設置撼港,動畫移動固定時間進行判斷一次,到達最終點為準骤竹。
  • 不要用tables布局的另一個原因就是tables中某個元素一旦觸發(fā)reflow就會導致table里所有的其它元素reflow帝牡。在適合用table的場合,可以設置table-layout為auto或fixed蒙揣,這樣可以讓table一行一行的渲染靶溜,這種做法也是為了限制reflow的影響范圍。
  • 減少不必要的 DOM 層級(DOM depth)懒震。改變 DOM 樹中的一級會導致所有層級的改變墨技,上至根部,下至被改變節(jié)點的子節(jié)點挎狸。這導致大量時間耗費在執(zhí)行 reflow 上面扣汪。
  • 減少不必要的 DOM 層級(DOM depth)。改變 DOM 樹中的一級會導致所有層級的改變锨匆,上至根部崭别,下至被改變節(jié)點的子節(jié)點。這導致大量時間耗費在執(zhí)行 reflow 上面恐锣。
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末茅主,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子土榴,更是在濱河造成了極大的恐慌诀姚,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,718評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件玷禽,死亡現(xiàn)場離奇詭異赫段,居然都是意外死亡,警方通過查閱死者的電腦和手機矢赁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評論 3 385
  • 文/潘曉璐 我一進店門糯笙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人撩银,你說我怎么就攤上這事给涕。” “怎么了?”我有些...
    開封第一講書人閱讀 158,207評論 0 348
  • 文/不壞的土叔 我叫張陵够庙,是天一觀的道長恭应。 經常有香客問我,道長耘眨,這世上最難降的妖魔是什么暮屡? 我笑而不...
    開封第一講書人閱讀 56,755評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮毅桃,結果婚禮上褒纲,老公的妹妹穿的比我還像新娘。我一直安慰自己钥飞,他們只是感情好募狂,可當我...
    茶點故事閱讀 65,862評論 6 386
  • 文/花漫 我一把揭開白布恢共。 她就那樣靜靜地躺著秤茅,像睡著了一般懈词。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上结闸,一...
    開封第一講書人閱讀 50,050評論 1 291
  • 那天唇兑,我揣著相機與錄音,去河邊找鬼桦锄。 笑死扎附,一個胖子當著我的面吹牛,可吹牛的內容都是我干的结耀。 我是一名探鬼主播留夜,決...
    沈念sama閱讀 39,136評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼图甜!你這毒婦竟也來了碍粥?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,882評論 0 268
  • 序言:老撾萬榮一對情侶失蹤黑毅,失蹤者是張志新(化名)和其女友劉穎嚼摩,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體矿瘦,經...
    沈念sama閱讀 44,330評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡枕面,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,651評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了匪凡。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片膊畴。...
    茶點故事閱讀 38,789評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖病游,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤衬衬,帶...
    沈念sama閱讀 34,477評論 4 333
  • 正文 年R本政府宣布买猖,位于F島的核電站,受9級特大地震影響滋尉,放射性物質發(fā)生泄漏玉控。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,135評論 3 317
  • 文/蒙蒙 一狮惜、第九天 我趴在偏房一處隱蔽的房頂上張望高诺。 院中可真熱鬧,春花似錦碾篡、人聲如沸虱而。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽牡拇。三九已至,卻和暖如春穆律,著一層夾襖步出監(jiān)牢的瞬間惠呼,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評論 1 267
  • 我被黑心中介騙來泰國打工峦耘, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留剔蹋,地道東北人。 一個月前我還...
    沈念sama閱讀 46,598評論 2 362
  • 正文 我出身青樓辅髓,卻偏偏與公主長得像滩租,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子利朵,可洞房花燭夜當晚...
    茶點故事閱讀 43,697評論 2 351

推薦閱讀更多精彩內容