如何用AI技术降噪? QCon 广州“音视频架构实践”专场给你答案! 了解详情
写点什么

提升页面渲染速度的 4 个 CSS 技巧

  • 2020 年 12 月 31 日
  • 本文字数:2792 字

    阅读完需:约 9 分钟

提升页面渲染速度的4个CSS技巧

用户喜欢快速的 Web 应用。他们期望页面加载速度快,运行流畅。如果滚动时出现动画中断或延迟,用户很可能就会离开你的网站。作为一名开发者,你可以做很多事情来提升用户体验。本文主要介绍你可以用来提升页面渲染速度的 4 个 CSS 技巧。

1. Content-visibility


一般来说,大部分 Web 应用都有复杂的 UI 元素,并且它的扩展超出了用户在浏览器视图中所能看到的范围。在这种情况下,我们可以使用content-visibility 来跳过渲染屏幕之外的内容。如果你有大量屏幕之外的内容的话,这会大大减少页面渲染时间。


这个功能是最新添加的功能之一,而且它是提升渲染性能最有影响力的功能之一。content-visibility 接受几个值,我们可以在一个元素上使用content-visibility: auto; 来立即获得性能提升。


我们可以看下面这个页面,包含很多显示不同信息的卡片。虽然屏幕能显示大约 12 个卡片,但列表中有差不多 375 个卡片。如你所见,浏览器花费 1037ms 来渲染这个页面。



一般 HTML 页面


下一步,你可以向所有的卡片中加入content-visibility


在这个例子中,向页面中加入content-visibility 后,渲染时间下降到 150ms。性能提升了 6 倍以上。



使用 content-visibility


如你所见,content-visibility 的功能很强大,对于改善页面渲染时间非常有用。根据我们目前为止讨论的内容,你一定在想它是针对页面渲染的灵丹妙药。


content-visibility 的限制


然而,也有一些领域 content-visibility 不适合。我想强调 2 点供你考虑。


  • 这个功能还是实验性的。目前,Firefox(PC 和 Android 版本)、Internet Explorer (我不认为他们计划向 IE 中添加这个功能)以及 Safari (Mac 和 iOS) 不支持 content-visibility。

  • 与滚动条行为相关的问题。由于元素最初渲染的高度是 0px,当你向下滚动时,这些元素会进入屏幕。实际的内容会被渲染,这个元素的高度会被相应地更新。这会使滚动条出现预料之外的行为。



使用 content-visibility 的滚动行为


为了修复这个滚动条问题,你可以使用另一个 CSS 属性,contain-intrinsic-size 。它指定了一个元素的自然大小。因此,这个元素会用指定的高度渲染,而不是 0px。


.element{    content-visibility: auto;    contain-intrinsic-size: 200px;}
复制代码


然而,在实验时,我发现即使使用containt-intrinsic-size ,如果我们有很多元素都使用content-visibility  且设置为auto ,你仍然会有微小的滚动条问题。


因此,我的建议是规划你的布局,将它分解为几个部分,然后在那几个部分上使用 content-visibility 来获取更好的滚动条行为。

2. Will-change 属性


浏览器上的动画并不是一个新鲜事物。通常,这些动画与其它元素一起正常渲染。然而,浏览器现在能够使用 GPU 来优化这些动画的某些操作。


使用 will-change CSS 属性,我们可以表明该元素将要修改特定的属性,让浏览器提前执行必要的优化。


底层发生的是,浏览器会为这个元素创建一个单独的层。然后,浏览器将这个元素的渲染委托给 GPU,以及其它一些优化。由于 GPU 加速接管了动画渲染,最终这个动画会更流畅。


考虑如下 CSS 类:


// In stylesheet.animating-element {  will-change: opacity;}// In HTML<div class="animating-elememt">  Animating Child elements</div>
复制代码


当在浏览器中渲染上面的代码时,它会识别出will-change 属性,并优化未来与不透明度 opacity 相关的变更。


根据Maximillian Laumeister所做的性能基准测试,你可以看到他只改变了一行代码就获得了超过 120FPS 的渲染速度,而最初的渲染速度大约是 50FPS。



不使用 will-change;图片来源:Maximilian



使用 will-change;图片来源:Maximilian

什么时候不要用 will-change


尽管will-change 是用来提升性能的,但如果你误用它,也会降低 Web 应用的性能。


  • 使用will-change 表明这个元素将来会改变


因此,如果你试图将will-change 与同步动画一起使用,它不会给你优化。因此,建议在父元素上使用 will-change,在子元素上使用动画。


.my-class{  will-change: opacity;}.child-class{  transition: opacity 1s ease-in-out;}
复制代码


  • 不要使用未设置动画的元素。当你在一个元素上使用will-change ,浏览器会尝试通过将它放到一个新层中并将转换移交给 GPU 来优化它。如果你没有要转换的东西,这会导致资源浪费。


最后要记住的是,建议在完成所有动画之后将 will-change 从元素上删除。


3. 减少渲染阻塞时间


今天,许多 Web 应用必须满足许多形式因素,包括 PC、平板电脑和移动手机等。为了实现这种响应式特性,我们必须根据媒介大小编写新的样式。在页面渲染时,直到 CSS 对象模型(CSS Object Model,CSSOM)准备就绪,它才开始渲染阶段。根据你的 Web 应用,你可能有一个很大的样式表来满足所有的设备形式因素。


然而,假设我们根据形式因素将它拆分成多个样式表。在这种情况下,我们可以只让主CSS文件阻塞关键路径,并将其优先下载,让其它样式表以低优先级的方式下载。


<link rel="stylesheet" href="styles.css">
复制代码



单个样式表


在将它分解成多个样式表后:


<!-- style.css contains only the minimal styles needed for the page rendering --><link rel="stylesheet" href="styles.css" media="all" /><!-- Following stylesheets have only the styles necessary for the form factor --><link rel="stylesheet" href="sm.css" media="(min-width: 20em)" /><link rel="stylesheet" href="md.css" media="(min-width: 64em)" /><link rel="stylesheet" href="lg.css" media="(min-width: 90em)" /><link rel="stylesheet" href="ex.css" media="(min-width: 120em)" /><link rel="stylesheet" href="print.css" media="print" />
复制代码



如你所见,根据形式因素拆分样式表能够减少渲染阻塞时间。

4. 避免使用 @import 来包含多个样式表


使用@import ,我们可以在一个样式表中包含另一个样式表。当我们在处理一个大型项目时,使用@import 会让代码更简洁。


关于@import 的一个关键事实是,它是一个阻塞调用,因为它必须发起一个网络请求来获取这个文件,解析它,然后将它包含在样式表中。如果我们在样式表中有嵌套的 @import ,它会妨碍渲染性能。


# style.css@import url("windows.css");# windows.css@import url("componenets.css");
复制代码



使用 imports 的瀑布图


与其使用@import ,我们可以使用多个链接 link 实现相同的功能且具有更好的性能,因为它允许并行下载样式表。



使用链接的瀑布图

结论


除了本文我们讨论的 4 个方面,还有一些其它的方法我们可以使用 CSS 来提高 Web 页面的性能。CSS 最新的特性之一,content-visibility, 在未来几年看起来很有前景,因为它可以在页面渲染方面带来数倍的性能提升。


最重要的是,我们不用编写一句 JavaScript 代码就可以获得所有这些性能提升。


我相信,你可以结合以上特性,为最终用户构建性能更好的 Web 应用。我希望这篇文章是有用的,如果你知道任何可以提升 Web 应用性能的 CSS 技巧,请在评论中留言。谢谢!


原文链接


Improve Page Rendering Speed Using Only CSS


2020 年 12 月 31 日 16:212327

评论

发布
暂无评论
发现更多内容

🔎【Java 源码探索】深入浅出的分析Mutex底层源码

浩宇の天尚

Java JVM mutex Condition 5月日更

知乎的一次29.7元的咨询

why技术

Java 程序员

阿里面试题:MySQL 磁盘满了,怎么办?

Java架构师迁哥

Java程序员简历这么写,还过不了筛选算我输!

Java架构师迁哥

长连接网关技术专题(五):喜马拉雅自研亿级API网关技术实践

JackJiang

Netty nio 网关

OpenResty入门

捉虫大师

nginx openresty

并发王者课-青铜8:分工协作-从本质认知线程的状态和动作方法

MetaThoughts

Java 多线程 并发 并发王者课

新生代小鲜肉之代码生成器

蛋先生DX

node.js 效率工具 自动化 生成代码

思想与落地

型火🔥

架构 分布式 微服务 哲学

Geek 青年说北京沙龙分享

看山

Geek青年说

怎样节省 2/3 的 GPU?爱奇艺 vGPU 的探索与实践

爱奇艺技术产品团队

深度学习 gpu

简单又灵活的权限设计?

蛋先生DX

数据库设计 权限系统 权限 权限架构 rbac

日常Bug排查-系统失去响应-Redis使用不当

无毁的湖光

Java redis

刚刚接触视频剪辑,怎么快速剪视频?

奈奈的杂社

Spring 实例化方式有几种?为什么会用到 Cglib?

小傅哥

Java spring 小傅哥 cglib 手写框架

SphereEx 获数百万美元天使融资,接力 ShardingSphere 开启 Database Plus 新篇章

SphereEx

个推“D-M-P”三步走, 打造每日治数平台,助力行业数字化升级

个推

大数据 数据中台 数据治理 数据智能

五分钟开发属于你自己的代码生成器

蛋先生DX

node.js 效率工具 生成代码 JavaScrip

从零开始学习ThingJS之创建/销毁物体

森友小锘

JavaScript 3D 3D可视化 数字孪生

和12岁小同志搞创客开发:如何选择合适的传感器?

不脱发的程序猿

DIY 传感器 创客开发 如何选择合适的传感器?

Springboot actuator不可不注意的安全问题-可越权-可脱库

果果果

安全 springboot

阿里云 AI 编辑部获 CCBN 创新奖,揭秘传媒行业解决方案背后的黑科技

阿里云视频云

阿里云 媒体 CCBN

千亿级数据迁移mongodb成本节省及性能优化实践

杨亚洲(专注MongoDB及高性能中间件)

MySQL 数据库 mongodb 架构 分布式数据库mongodb

.Net Core Configuration Etcd数据源

yi念之间

etcd .net core

QCon 演讲实录 | 大型软件团队的数字化项目管理实践

万事ONES

研发管理 团队协作 数字化 ONES Qcon

华云大咖说 | 华云数据助力高校建设实训室平台

华云数据

如何优化你的HTTPS?

运维研习社

https HTTP2.0 5月日更

非官方不权威Java面试宝典

北游学Java

Java 面试

促成“零碳”社会的全面实现,华为云让技术更有温度

xiaotan

华为云

「云智公开课」百度沧海·存储

「云智公开课」百度沧海·存储

提升页面渲染速度的4个CSS技巧_架构_Rumesh Eranga Hapuarachchi_InfoQ精选文章