gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区

站長資訊網
最全最豐富的資訊網站

聊聊CSS新特性content-visibility,助你提升頁面渲染性能

聊聊CSS新特性content-visibility,助你提升頁面渲染性能

前端(vue)入門到精通課程:進入學習
Apipost = Postman + Swagger + Mock + Jmeter 超好用的API調試工具:點擊使用

對于前端人員來講,最令人頭疼的應該就是頁面性能了,當用戶在訪問一個頁面時,總是希望它能夠快速呈現在眼前并且是可交互狀態。如果頁面加載過慢,你的用戶很可能會因此離你而去。所以頁面性能對于前端開發者來說可謂是重中之重,其實你如果了解頁面從加載到渲染完成的整個過程,就知道應該從哪方面下手了。

嗯,不要跑偏了,今天我們主要來研究長列表頁面的渲染性能

現如今的頁面越來越復雜,一個頁面往往承載著大量的元素,最常見的就是一些電商頁面,數以萬計的商品列表是怎么保證渲染不卡頓的,大家在面對這種長列表渲染的場景下,一般都會采用分頁或者虛擬列表來減緩頁面一次性渲染的壓力,但這些方式都需要配合JS來時實現,那么有沒有僅使用CSS就能夠實現的方案呢?

答案是有的,它就是我們今天的主角 —— 內容可見性(content-visibility)。【推薦學習:css視頻教程】

content-visibility

屬性值

content-visibility是CSS新增的屬性,主要用來提高頁面渲染性能,它可以控制一個元素是否渲染其內容,并且允許瀏覽器跳過這些元素的布局與渲染。

  • visible:默認值,沒有效果。元素的內容被正常布局和呈現。
  • hidden:元素跳過它的內容。跳過的內容不能被用戶代理功能訪問,例如在頁面中查找、標簽順序導航等,也不能被選擇或聚焦。這類似于給內容設置display: none
  • auto:該元素打開布局包含、樣式包含和繪制包含。如果該元素與用戶不相關,它也會跳過其內容。與 hidden 不同,跳過的內容必須仍可正常用于用戶代理功能,例如在頁面中查找、tab 順序導航等,并且必須正常可聚焦和可選擇。

content-visibility: hidden手動管理可見性

上面說到content-visibility: hidden的效果與display: none類似,但其實兩者還是有比較大的區別的:

  • content-visibility: hidden 只是隱藏了子元素,自身不會被隱藏
  • content-visibility: hidden 隱藏內容的渲染狀態會被緩存,所以當它被移除或者設為可見時,瀏覽器不會重新渲染,而是會應用緩存,所以對于需要頻繁切換顯示隱藏的元素,這個屬性能夠極大地提高渲染性能。

聊聊CSS新特性content-visibility,助你提升頁面渲染性能

從這上面我們可以看到,添加了content-visibility: hidden元素的子元素確實是沒有渲染,但它自身是會渲染的!

content-visibility: auto 跳過渲染工作

我們仔細想想,頁面上雖然會有很多元素,但是它們會同時呈現在用戶眼前嗎,很顯然是不會的,用戶每次能夠真實看到就只有設備可見區那些內容,對于非可見區的內容只要頁面不發生滾動,用戶就永遠看不到。雖然用戶看不到,但瀏覽器卻會實實在在的去渲染,以至于浪費大量的性能。所以我們得想辦法讓瀏覽器不渲染非可視區的內容就能夠達到提高頁面渲染性能的效果。

我們上面說到的虛擬列表原理其實就跟這個類似,在首屏加載時,只加載可視區的內容,當頁面發生滾動時,動態通過計算獲得可視區的內容,并將非可視區的內容進行刪除,這樣就能夠大大提高長列表的渲染性能。

但這個需要配合JS才能實現,現在我們可以使用CSS中content-visibility: auto,它可以用來跳過屏幕外的內容渲染,對于這種有大量離屏內容的長列表,可以大大減少頁面渲染時間。

我們將上面的例子稍微改改:

<template>   <div>     <div>       <img :src="book.bookCover" />       <div>         <div>{{ `${book.bookName}${index + 1}` }}</div>         <div>{{ book.catlog }}</div>         <div>           <div v-for="(item, index) in book.tags" :key="index">             {{ item }}           </div>         </div>         <div>           {{ book.desc }}         </div>       </div>     </div>   </div> </template>  <script setup> import { toRefs } from "vue";  const props = defineProps<{   book: any;   index: any; }>(); const { book, index } = toRefs(props); </script>  <style scoped> .card_item {   margin: 20px auto;   content-visibility: auto; }   / *   ...   */ </style>
登錄后復制

首先是沒有添加content-visibility: auto的效果,無論這些元素是否在可視區,都會被渲染

聊聊CSS新特性content-visibility,助你提升頁面渲染性能

如果我們在平常業務中這樣寫,用戶進入到這個頁面可能就直接口吐芬芳了,為了性能考慮,我們為每一個列表項加上:

.card_item {   content-visibility: auto; }
登錄后復制

這個時候我們再來看下效果:

聊聊CSS新特性content-visibility,助你提升頁面渲染性能

從第10個開始,這些沒在可視區的元素就沒有被渲染,這可比上面那種全部元素都渲染好太多了,但是如果瀏覽器不渲染頁面內的一些元素,滾動將是一場噩夢,因為無法正確計算頁面高度。這是因為,content-visibility會將分配給它的元素的高度(height)視為0,瀏覽器在渲染之前會將這個元素的高度變為0,從而使我們的頁面高度和滾動變得混亂。

聊聊CSS新特性content-visibility,助你提升頁面渲染性能

這里我們可以看到頁面上的滾動條會出現抖動現象,這是因為可視區外的元素只有出現在了可視區才會被渲染,這就回導致前后頁面高度會發生變化,從而出現滾動條的詭異抖動現象,這是虛擬列表基本都會存在的問題。

⚠️注意:當元素接近視口時,瀏覽器不再添加size容器并開始繪制和命中測試元素的內容。這使得渲染工作能夠及時完成以供用戶查看。

這也是為什么上面我們看到的是從第十個才開始不渲染子元素,因為它需要一個緩沖區以便瀏覽器能夠在頁面發生滾動時及時渲染呈現在用戶眼前。

上面提到的size其實是一種 CSS 屬性的潛在值contain,它指的是元素上的大小限制確保元素的框可以在不需要檢查其后代的情況下進行布局。這意味著如果我們只需要元素的大小,我們可以跳過后代的布局。

contain-intrinsic-size 救場

頁面在滾動過程中滾動條一直抖動,這是一個不能接受的體驗問題,為了更好地實現content-visibility,瀏覽器需要應用 size containment 以確保內容的渲染結果不會以任何方式影響元素的大小。這意味著該元素將像空的一樣布局。如果元素沒有在常規塊布局中指定的高度,那么它將是 0 高度。

這個時候我們可以使用contain-intrinsic-size來指定的元素自然大小,確保我們未渲染子元素的 div 仍然占據空間,同時也保留延遲渲染的好處。

語法

此屬性是以下 CSS 屬性的簡寫:

  • contain-intrinsic-width
  • contain-intrinsic-height

/* Keyword values */ contain-intrinsic-width: none;  /* <length> values */ contain-intrinsic-size: 1000px; contain-intrinsic-size: 10rem;  /* width | height */ contain-intrinsic-size: 1000px 1.5em;  /* auto <length> */ contain-intrinsic-size: auto 300px;  /* auto width | auto height */ contain-intrinsic-size: auto 300px auto 4rem;
登錄后復制

contain-intrinsic-size 可以為元素指定以下一個或兩個值。如果指定了兩個值,則第一個值適用于寬度,第二個值適用于高度。如果指定單個值,則它適用于寬度和高度。

實現

我們只需要給添加了content-visibility: auto的元素添加上contain-intrinsic-size就能夠解決滾動條抖動的問題,當然,這個高度約接近真實渲染的高度,效果會越好,如果實在無法知道準確的高度,我們也可以給一個大概的值,也會使滾動條的問題相對減少。

.card_item {   content-visibility: auto;   contain-intrinsic-size: 200px; }
登錄后復制

聊聊CSS新特性content-visibility,助你提升頁面渲染性能

之前沒添加contain-intrinsic-size屬性時,可視區外的元素高度都是0,現在這些元素高度都是我們設置的contain-intrinsic-size的值,這樣的話整個頁面的高度就是不會發生變化(或者說變化很小),從而頁面滾動條也不會出現抖動問題(或者說抖動減少)

聊聊CSS新特性content-visibility,助你提升頁面渲染性能

性能對比

上面說了這么多,content-visibility是否真的能夠提高頁面的渲染性能呢,我們來實際對比看看:

  • 首先是沒有content-visibility的頁面渲染

聊聊CSS新特性content-visibility,助你提升頁面渲染性能

  • 然后是有content-visibility的頁面渲染

聊聊CSS新特性content-visibility,助你提升頁面渲染性能

上面是用1000個列表元素進行測試的,有content-visibility的頁面渲染花費時間大概是37ms,而沒有content-visibility的頁面渲染花費時間大概是269ms,提升了足足有7倍之多!!!

對于列表元素

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
欧美一级片免费播放| 男的插女的下面视频| 黄色三级视频在线| 国产永久免费网站| 日本欧美视频在线观看| 欧美性猛交xxxx乱大交91| 国产精品久久国产| 黄色一级片免费的| 日韩视频第二页| 国产精品人人爽人人爽| 色七七在线观看| 国产主播在线看| 国产自产在线视频| 国产精品视频网站在线观看| 2022亚洲天堂| 春日野结衣av| 欧美在线一区视频| 亚洲精品无码久久久久久| 国内av免费观看| 国产精品国产对白熟妇| 欧美aaa在线观看| 国产一区二区在线观看免费视频| 黄色网页免费在线观看| 男女h黄动漫啪啪无遮挡软件| 青青草原国产免费| 中日韩av在线播放| 网站在线你懂的| 福利视频999| 在线观看18视频网站| 美国av在线播放| 国产乱子伦农村叉叉叉| 亚洲熟妇无码一区二区三区导航| 国产h视频在线播放| 在线免费观看视频黄| 僵尸世界大战2 在线播放| 艹b视频在线观看| 天天影视综合色| 亚洲精品永久视频| 霍思燕三级露全乳照| 99久久久无码国产精品6| 日韩av片网站| 日本免费不卡一区二区| 霍思燕三级露全乳照| 国产免费一区二区三区四在线播放 | 国产一级片自拍| 国产探花在线观看视频| 中文字幕第一页亚洲| 超碰人人草人人| 亚欧激情乱码久久久久久久久| 久久久久久久久久久福利| 国产一区二区在线视频播放| www.18av.com| 无码人妻精品一区二区三区在线| 日韩免费一级视频| 麻豆传传媒久久久爱| 成 人 黄 色 小说网站 s色| 亚洲制服在线观看| 日韩视频免费播放| 手机版av在线| 成人网站免费观看入口| 色诱视频在线观看| 天堂av手机在线| 成人av一级片| 日本一本草久p| 亚洲欧美在线精品| 久久这里只有精品18| 久久久免费视频网站| 国产嫩草在线观看| 黄色成人在线免费观看| 日本超碰在线观看| 国产精品沙发午睡系列| 国产内射老熟女aaaa| 久久精品影视大全| www在线观看免费| 成人在线播放网址| 成年人黄色在线观看| 无尽裸体动漫2d在线观看| 免费激情视频在线观看| 各处沟厕大尺度偷拍女厕嘘嘘| 91精品国产吴梦梦| 久久精品一卡二卡| 成年人免费观看的视频| 四季av一区二区三区| 特黄视频免费观看| 红桃视频 国产| 日本福利视频导航| 天堂av8在线| 亚洲乱码中文字幕久久孕妇黑人| 一本二本三本亚洲码| 91丨九色丨蝌蚪| 免费成年人高清视频| 污污的网站18| 韩国黄色一级大片| 黄色小视频大全| 福利视频一二区| av免费看网址| 18禁男女爽爽爽午夜网站免费 | av电影一区二区三区| 亚洲中文字幕无码不卡电影| 裸体裸乳免费看| 夜夜爽久久精品91| 亚洲成人手机在线观看| 国产一级特黄a大片免费| 欧美一级视频免费看| 黄页网站大全在线观看| 免费欧美一级视频| 国产日产欧美视频| 色婷婷成人在线| 天天色综合天天色| 一区二区三区四区毛片| 人人爽人人爽av| 日韩中文在线字幕| av黄色在线网站| 成人黄色一级大片| 日本a级片在线播放| 无码人妻丰满熟妇区96| 狠狠躁狠狠躁视频专区| 中文字幕日本最新乱码视频| 日韩人妻精品无码一区二区三区| 嫩草影院中文字幕| 99在线精品免费视频| 日韩人妻无码精品久久久不卡| 欧美精品久久久久久久自慰| 成人精品视频在线播放| 成 年 人 黄 色 大 片大 全| 国产欧美日韩小视频| av观看免费在线| 亚洲精品偷拍视频| 欧美一级黄色影院| 黄色网址在线免费看| 激情网站五月天| 黄色影视在线观看| 91看片在线免费观看| 久久久噜噜噜www成人网| 男人的天堂视频在线| 中文字幕一区久久| 91丨九色丨蝌蚪| 爱情岛论坛亚洲首页入口章节| 无码人妻精品一区二区三区99v| 国产一区亚洲二区三区| 免费av网址在线| 冲田杏梨av在线| 成人免费在线观看视频网站| 国产精品无码av无码| 无码人妻丰满熟妇区五十路百度| 人妻无码久久一区二区三区免费| 特级西西444| 欧日韩免费视频| 成人免费xxxxx在线视频| 成年人免费大片| 亚洲黄色小视频在线观看| 天天干天天色天天干| 成年人黄色在线观看| 妞干网视频在线观看| 亚洲午夜无码av毛片久久| 中文字幕国产高清| 青青青在线观看视频| 日韩一级片播放| 香港三级日本三级a视频| 日韩视频在线视频| 亚洲欧美日本一区二区三区| 大地资源网在线观看免费官网| av网站在线观看不卡| 免费日韩在线观看| 久热精品在线观看视频| 成人免费观看cn| av免费在线播放网站| 看一级黄色录像| 成人手机在线播放| 国产一二三四五| 免费网站在线观看视频 | 女人天堂av手机在线| 国产精品久久中文字幕| 400部精品国偷自产在线观看| 无限资源日本好片| 在线免费看v片| 日本高清视频免费在线观看| 亚洲精品无码国产| 国产成人无码精品久久久性色| 久久av综合网| 日本成人黄色网| 99九九精品视频| 久久久久久久久久久视频| 99色精品视频| 在线观看免费黄色片| 日韩国产一级片| 日本中文字幕在线不卡| www插插插无码免费视频网站| 国产午夜伦鲁鲁| 裸体大乳女做爰69| 别急慢慢来1978如如2| 日本美女久久久| 黄色一级大片在线观看| 成人午夜免费剧场| 亚欧在线免费观看| 国产精品成人久久电影| 99热都是精品| 蜜臀一区二区三区精品免费视频| 男人天堂1024| 国产伦精品一区二区三区四区视频_|