2021-01-11 前端性能

1、重繪(Repaint)
重繪(repaint或redraw):當盒子的位置、大小以及其他屬性,例如顏色绘闷、字體大小等都確定下來之后橡庞,瀏覽器便把這些原色都按照各自的特性繪制一遍,將內容呈現在頁面上印蔗。重繪是指一個元素外觀的改變所觸發(fā)的瀏覽器行為扒最,瀏覽器會根據元素的新屬性重新繪制,使元素呈現新的外觀华嘹。
重繪不會帶來重新布局扼倘,所以并不一定伴隨重排。
"重繪"不一定需要"重排"除呵,比如改變某個網頁元素的顏色再菊,就只會觸發(fā)"重繪",不會觸發(fā)"重排"颜曾,因為布局沒有改變纠拔。
但是,"重排"必然導致"重繪"泛豪,比如改變一個網頁元素的位置稠诲,就會同時觸發(fā)"重排"和"重繪",因為布局改變了诡曙。
2臀叙、重排(Reflow)
重排(重構/回流/reflow):當渲染樹中的一部分(或全部)因為元素的規(guī)模尺寸,布局价卤,隱藏等改變而需要重新構建, 這就稱為回流(reflow)劝萤。每個頁面至少需要一次回流,就是在頁面第一次加載的時候慎璧。
渲染對象在創(chuàng)建完成并添加到渲染樹時床嫌,并不包含位置和大小信息。計算這些值的過程就稱為布局或重排胸私。
Reflow 的成本比 Repaint 的成本高得多的多厌处。DOM Tree 里的每個結點都會有 reflow 方法,
一個結點的 reflow 很有可能導致子結點岁疼,甚至父點以及同級結點的 reflow阔涉。在一些高性能的電腦上也許還沒什么,
但是如果 reflow 發(fā)生在手機上捷绒,那么這個過程是消耗內存性能和耗電的瑰排。
重排必定會引發(fā)重繪,但重繪不一定會引發(fā)重排疙驾。
觸發(fā)重排的條件:
任何頁面布局和幾何屬性的改變都會觸發(fā)重排凶伙,比如:
1、頁面渲染初始化它碎;(無法避免)
2、添加或刪除可見的DOM元素;
3扳肛、元素位置的改變傻挂,或者使用動畫;
4挖息、元素尺寸的改變——大小金拒,外邊距,邊框套腹;
5绪抛、瀏覽器窗口尺寸的變化(resize事件發(fā)生時);
6电禀、填充內容的改變幢码,比如文本的改變或圖片大小改變而引起的計算值寬度和高度的改變;
7尖飞、讀取某些元素屬性:(offsetLeft/Top/Height/Width, clientTop/Left/Width/Height, scrollTop/Left/Width/Height, width/height, getComputedStyle(), currentStyle(IE) )
重繪發(fā)生的情況:
重繪發(fā)生在元素的可見的外觀被改變症副,但并沒有影響到布局的時候。比如政基,僅修改DOM元素的字體顏色(只有Repaint贞铣,因為不需要調整布局)
1、改變字體
2沮明、增加或者移出樣式表
3辕坝、內容變化,比如用戶在input框中輸入文字
4荐健、激活css偽類圣勒,比如:hover
5、腳本操作DOM
6摧扇、計算offsetWidth和offsetHeight屬性
7圣贸、設置style屬性的值

image.png

image.png

image.png

1、前端性能指標

  • FP 首次繪制
  • FCP 首次內容繪制
  • FMP 首次有效繪制
  • TTI 可交互時間

2扛稽、前端頁面渲染流程

  • HTML頁面請求
    • HTML文檔下載
      • html -> 文檔自身
      • javascript -> js
      • link -> css
      • video -> .ogg .mp4
      • audio -> .mp3
      • img -> 圖片src
    • HTML文檔解析(按順序依次執(zhí)行)
      • dom樹生成(html文檔中所有標簽元素吁峻,不管該標簽在頁面中是否實際可見)
      • render樹生成(結合css樣式、js代碼繪制成的頁面實際展示的dom元素)
      • 逐級解析dom樹
        • p在张、label用含、ol、a等等一般不引用外部資源的標簽
        • link帮匾、javascript啄骇、img可引用外部資源的標簽
          • link -> css、盡量減少頁面的reflow (reflow-回流:當頁面結構發(fā)生改變時瘟斜,例如當元素位置發(fā)生改變缸夹,比如某個元素的margin痪寻、padding的改變導致其他元素位置的變化,或者說render樹被重新組裝虽惭;repaint-重繪)
          • javascript -> js橡类,js繪制dom節(jié)點會阻塞其他標簽接解析、甚至下載
          • img -> 圖片src芽唇,圖片加載可以先使用分辨率較低的圖片
  • 瀏覽器的js引擎

3顾画、技術優(yōu)化出發(fā)點

  • 復用(維護性、開發(fā)成本)
    • 前端復用
    • 后端復用
  • 加載方式(提升用戶體驗)
    • 同步加載
      • 都加載完才能展示給用戶想看的
      • 可能很少的tcp連接就能完成頁面的加載
    • 分級加載
      • 同步加載和異步加載相結合
      • 先給用戶加載重要信息匆笤,比如logo/核心功能研侣,后面加載不重要的
    • 按需加載
      • 用戶不觸發(fā)該功能我們就不加載
      • 用戶不觸發(fā)該功能,但是寬帶閑置炮捧,或者頁面的主要元素都加載完了庶诡,就可以加載
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市寓盗,隨后出現的幾起案子灌砖,更是在濱河造成了極大的恐慌,老刑警劉巖傀蚌,帶你破解...
    沈念sama閱讀 212,884評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件基显,死亡現場離奇詭異,居然都是意外死亡善炫,警方通過查閱死者的電腦和手機撩幽,發(fā)現死者居然都...
    沈念sama閱讀 90,755評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來箩艺,“玉大人窜醉,你說我怎么就攤上這事∫兆唬” “怎么了榨惰?”我有些...
    開封第一講書人閱讀 158,369評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長静汤。 經常有香客問我琅催,道長,這世上最難降的妖魔是什么虫给? 我笑而不...
    開封第一講書人閱讀 56,799評論 1 285
  • 正文 為了忘掉前任藤抡,我火速辦了婚禮,結果婚禮上抹估,老公的妹妹穿的比我還像新娘缠黍。我一直安慰自己,他們只是感情好药蜻,可當我...
    茶點故事閱讀 65,910評論 6 386
  • 文/花漫 我一把揭開白布瓷式。 她就那樣靜靜地躺著替饿,像睡著了一般。 火紅的嫁衣襯著肌膚如雪蒿往。 梳的紋絲不亂的頭發(fā)上盛垦,一...
    開封第一講書人閱讀 50,096評論 1 291
  • 那天湿弦,我揣著相機與錄音瓤漏,去河邊找鬼。 笑死颊埃,一個胖子當著我的面吹牛蔬充,可吹牛的內容都是我干的。 我是一名探鬼主播班利,決...
    沈念sama閱讀 39,159評論 3 411
  • 文/蒼蘭香墨 我猛地睜開眼饥漫,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了罗标?” 一聲冷哼從身側響起庸队,我...
    開封第一講書人閱讀 37,917評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎闯割,沒想到半個月后彻消,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 44,360評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡宙拉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,673評論 2 327
  • 正文 我和宋清朗相戀三年宾尚,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片谢澈。...
    茶點故事閱讀 38,814評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡煌贴,死狀恐怖,靈堂內的尸體忽然破棺而出锥忿,到底是詐尸還是另有隱情牛郑,我是刑警寧澤,帶...
    沈念sama閱讀 34,509評論 4 334
  • 正文 年R本政府宣布敬鬓,位于F島的核電站淹朋,受9級特大地震影響,放射性物質發(fā)生泄漏列林。R本人自食惡果不足惜瑞你,卻給世界環(huán)境...
    茶點故事閱讀 40,156評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望希痴。 院中可真熱鬧者甲,春花似錦、人聲如沸砌创。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至刽辙,卻和暖如春窥岩,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背宰缤。 一陣腳步聲響...
    開封第一講書人閱讀 32,123評論 1 267
  • 我被黑心中介騙來泰國打工颂翼, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人慨灭。 一個月前我還...
    沈念sama閱讀 46,641評論 2 362
  • 正文 我出身青樓朦乏,卻偏偏與公主長得像,于是被迫代替她去往敵國和親氧骤。 傳聞我的和親對象是個殘疾皇子呻疹,可洞房花燭夜當晚...
    茶點故事閱讀 43,728評論 2 351

推薦閱讀更多精彩內容