97国产精品视频人人做人人爱,3344在线观看无码,成年人国产视频,欧美日一级片,在线看AV天堂,高清无码一本到东京热,欧美一级黄片一区2区,免费又爽又刺激高潮网址

高效前端之再探頁面渲染優化

2021-4-2    前端達人

首先仍然不得不提的是 “在客戶端拿到 HTML 后的處理”:

  • 從上到下解析 HTML 文檔生成DOM樹;
  • 加載解析樣式構建CSSOM樹;
  • 加載并執行JavaScript代碼;
  • 根據DOM樹和CSSOM樹,生成 render 樹;
  • 渲染;
  • 布局;
  • 繪制

我們可能很多次聽到過:“要盡可能地減少重排和重繪,因為它們會影響瀏覽器性能。”
但,為什么呢?

事實上,一個頁面是由許多層級組成的(就像千層餅一樣) —— 這里的“層級”指的是“ DOM 元素渲染層(Layer)”。一個頁面在構建完 render tree 到展現在我們面前還經歷了一個“特別的流程”:

  1. 瀏覽器會先獲取DOM樹并依據樣式將其分割成多個獨立的渲染層
  2. CPU 將每一層繪制進位圖中
  3. 將位圖作為紋理上傳至 GPU(顯卡)繪制
  4. GPU 將所有的渲染層緩存并復合多個渲染層最終形成我們的圖像(如果下次上傳的渲染層沒有發生變化,GPU 就不需要對其進行重新繪制)

(:從上面的步驟我們可以知道:布局是CPU處理的,而繪制是由GPU完成的。
就像這張圖說的(from Firefox的3D View插件的頁面Layers層級圖)
layer-index

問題就發生在上面所說流程的第2、4步中。大家試想一下:如果我們把那些會發生復雜運動/變化或一直發生大量重排重繪的元素提起出來,單獨放在一個渲染層觸發,那它就不會連累其他元素了!

那什么情況下會觸發渲染層呢?
比如 video 、WebGL 、Canvas 、CSS3 3D 、CSS濾鏡 、z-index大于某個相鄰節點的值 的元素都會觸發新的Layer —— 這里要理解一點:它并不單單指 z-index!這里極力推薦張鑫旭大大的這一篇文章:深入理解CSS中的層疊上下文和層疊順序
比較簡單的方法是,給元素加上下面的樣式:

transform: translateZ(0); backface-visibility: hidden; 
  • 1
  • 2

我們把容易觸發重排重繪的元素單獨觸發渲染層,讓它與那些“靜態”元素隔離,讓 GPU 分擔更多的渲染工作,我們通常把這樣的措施成為硬件加速,或者是 GPU 加速。大家之前肯定聽過這個說法 —— 就比如CSS中的 will-change 。

不論是重排還是重繪,都會阻塞瀏覽器。要提高網頁性能,就要降低重排和重繪的頻率和成本,近可能少地觸發重新渲染。正如我們上面提到的:重排是由 CPU 處理的,而重繪是由 GPU 處理的,CPU 的處理效率遠不及 GPU,并且重排一定會引發重繪,而重繪不一定會引發重排。所以在性能優化工作中,我們更應當著重減少重排的發生。


還有什么可以優化的?

  1. CSS 屬性讀寫分離:瀏覽器沒次對元素樣式進行讀操作時,都必須進行一次重新渲染(重排 + 重繪),所以我們在使用 JS 對元素樣式進行讀寫操作時,最好將兩者分離開,先讀后寫,避免出現兩者交叉使用的情況
  2. 通過切換 class 或者 style.csstext 屬性去批量操作元素樣式
  3. DOM 元素離線更新:當對 DOM 進行相關操作時,例、appendChild 等都可以使用 documentFragment 對象進行離屏操作,帶元素“組裝”完成后再一次插入頁面,或者使用 display:none 對元素隱藏,在元素“消失”后進行相關操作,然后再顯示出來
  4. visibility: hidden 是個好東西,它既有display的隱藏,又有opacity的占位。而且它還支持移動動畫
  5. 圖片在渲染前指定大?。阂驗?img 元素是內聯元素,所以在加載圖片后會改變寬高,嚴重的情況會導致整個頁面重排,所以最好在渲染前就指定其大小,或者讓其脫離文檔流

日歷

鏈接

個人資料

藍藍設計的小編 http://www.0391cbd.com

存檔

主站蜘蛛池模板: 国产丝袜第一页| 成人欧美日韩| 青青草国产精品久久久久| 国产日本视频91| 人妻一本久道久久综合久久鬼色| 操美女免费网站| 黑人巨大精品欧美一区二区区| 婷婷久久综合九色综合88| 国产电话自拍伊人| 国产性精品| 欧美精品亚洲精品日韩专区va| 毛片网站在线看| 国产精品99在线观看| 亚洲天堂视频在线观看免费| 国产成人h在线观看网站站| 黄色网页在线播放| 亚洲欧洲天堂色AV| 亚洲国产天堂久久综合226114| 99re热精品视频中文字幕不卡| 日本国产一区在线观看| 国产美女叼嘿视频免费看| 一本久道久综合久久鬼色| 免费一级毛片在线观看| 啪啪啪亚洲无码| 思思热在线视频精品| 国产美女精品人人做人人爽| 精品国产免费人成在线观看| 国产呦视频免费视频在线观看| 亚洲人成影视在线观看| 国产成人久久777777| 国产三级精品三级在线观看| 久久国产精品波多野结衣| 国产一级妓女av网站| 91九色最新地址| 国产成人亚洲欧美激情| 国产美女主播一级成人毛片| 国产午夜不卡| 毛片最新网址| 91口爆吞精国产对白第三集| 日本在线欧美在线| 国产真实自在自线免费精品| 19国产精品麻豆免费观看| 欧美在线视频不卡第一页| 国产哺乳奶水91在线播放| 9966国产精品视频| 91亚洲影院| 国产综合另类小说色区色噜噜 | 亚洲嫩模喷白浆| 永久免费av网站可以直接看的| 91精品视频在线播放| 国产成人综合日韩精品无码不卡| 91久久偷偷做嫩草影院精品| 人妻一本久道久久综合久久鬼色| 99人体免费视频| 欧美三级视频网站| 国产av剧情无码精品色午夜| A级毛片无码久久精品免费| 国产丝袜啪啪| 国产杨幂丝袜av在线播放| 亚洲黄色成人| 国内自拍久第一页| 久草网视频在线| 国产成人综合在线观看| 成人在线综合| 欧美一级专区免费大片| 潮喷在线无码白浆| 亚洲中文字幕在线一区播放| 青青草原国产精品啪啪视频| 亚洲欧美日韩成人高清在线一区| 久久国产黑丝袜视频| 国产九九精品视频| 亚洲人成日本在线观看| 日韩国产精品无码一区二区三区| 国内毛片视频| 亚洲AⅤ无码国产精品| 99er这里只有精品| 欧美日韩免费| 天堂网亚洲系列亚洲系列| 色噜噜狠狠色综合网图区| 99热国产在线精品99| 国产内射在线观看| 99九九成人免费视频精品|