降低性能的两行 CSS(fps 到 ps)

我最近发布了 learn wc,如果您看过它,您可能已经注意到背景中的动画,其中彩色圆圈在屏幕上对角移动。看起来像这样:

它在 chrome 和 safari 上运行良好,但我注意到 firefox 上的性能严重下降。

性能太差了,我直接在 firefox 中禁用了这个动画。

动画是如何运作的?

动画是使用两个嵌套的 div 构建的。外部 div 是网站 body 标签的第一个子级。

    

.background-gradient 元素负责创建跨越其父容器的整个宽度和高度的渐变。像这样:

降低性能的两行 CSS(fps 到 ps)

立即学习“前端免费学习笔记(深入)”;

外部 .background-mask 负责两件事:

它将位置设置为固定,并使容器填充视口的整个尺寸。在渐变上创建点状蒙版

这确保了点的颜色是其正下方渐变的颜色:

降低性能的两行 CSS(fps 到 ps)

这是我上面描述的所有内容的 css

.background-mask {    --mask-size: 24px;    /* position styles */    position: fixed;    width: 100%;    height: 100%;    z-index: -1;    /* mask styles */    mask-image: radial-gradient(black 2px, transparent 2px);    mask-size: var(--mask-size) var(--mask-size);    mask-position: 0px 0px;    animation: mask-move 3s infinite linear;}.background-gradient {    background: var(--red);    background-image: var(--gradient);    width: 100%;    height: 100%;}@keyframes mask-move {    0% {        mask-position: 0px 0px;    }    100% {        mask-position: var(--mask-size) var(--mask-size);    }}@media (prefers-reduced-motion: reduce) {    .hero-background-mask {        animation: none;    }}

如果您有兴趣了解有关 css 中蒙版的更多信息,那么我可以推荐 ahmad shadeed 撰写的这篇综合文章

是什么导致了性能下降?

并非所有 css 属性的动画效果都是一样的。无需过多讨论浏览器如何将 html 呈现到页面(尽管我已在此处概述),它会经历几个阶段。我们感兴趣的三个阶段是:

布局 – 当浏览器计算页面上元素的大小和位置绘制 – 绘制页面的所有视觉方面,如图像、颜色、阴影等复合 – 以正确的顺序将元素分层

管道的顺序如下所示:

布局→绘制→合成

布局和绘制过程可能会占用大量 cpu 资源,因此尝试减少 css 触发管道中各阶段的次数非常重要*。* 浏览器通过优化某些属性的性能在某种程度上提供了帮助,例如跳过渲染管道的整个阶段,其他人可以利用硬件加速将计算从cpu转移到gpu。

对某些属性进行动画处理,例如平移和不透明度,都可以避免触发布局并使用硬件加速。

遗憾的是,动画蒙版位置时并非如此。我查看了 chrome,发现背景 div 的绘制计数在每一帧上都在增加。几秒钟后,它已经触发了超过 1,000 次油漆。

降低性能的两行 CSS(fps 到 ps)

即使绘制数量如此之多,chrome 上的动画也感觉很流畅。然而,在 firefox 上感觉超级卡顿。令人烦恼的是,我找不到测量 firefox 上的绘制计数的方法,因此我对 firefox 糟糕性能所做的任何假设都纯粹是猜测。

我确实注意到动画对于小型设备来说很好,但随着屏幕尺寸的增加而变得更糟。我的工作原理是,firefox 不会对每个 24×24 蒙版进行批处理布局触发器,这会导致当存在更多 24×24 蒙版时 fps 下降。再说一次,我在这里可能完全错了。

我是如何解决这个问题的?

我需要依靠性能更高的属性,例如translate,而不是对优化不佳的 css 属性(如 mask-position )进行动画处理。

解决方案不是将蒙版移动 24px,而是使用平移属性移动整个背景元素。

从抽象的角度来看,动画是这样的:

这是 css 中的两行更改:

/* --mask-size = 24px */@keyframes mask-move {    0% {        transform: translate(calc(var(--mask-size) * -1), calc(var(--mask-size) * -1));    }    100% {        transform: translate(0px, 0px);    }}

浏览器不再对蒙版位置进行动画处理,这会在每个帧上触发布局。即使背景在每一帧上移动,通过翻译它也不会触发布局或绘制。你可以看到 only 绘制了两次,从每分钟 1,000+ 下降了。

降低性能的两行 CSS(fps 到 ps)

眼尖的观众一定会发现一个问题。如果您还记得的话,背景的高度和宽度会填充视口。将背景向左和向上移动 24 像素,在视口中留下这个空白区域。

降低性能的两行 CSS(fps 到 ps)

解决这个问题很简单,只需将遮罩尺寸添加到容器的宽度和高度即可:

.background-mask {    --mask-size: 24px;    width: calc(100% + var(--mask-size));    height: calc(100% + var(--mask-size));}

让我们在 firefox 中再看一下:

这可能不是一个完美的解决方案,但完成一个有趣的雾里看花css技巧总是让人有点满足。

以上就是降低性能的两行 CSS(fps 到 ps)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1629757.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 12:45:15
下一篇 2025年12月24日 12:45:27

相关推荐

  • 如何设置独立 CLI:在 Shopify 中使用 Tailwind CSS,而不使用 Nodejs

    依赖关系 Shopify CLI:一种命令行界面工具,可帮助您开发和管理 Shopify 主题。TailwindCSS:实用程序优先的 CSS 框架,用于快速构建自定义设计。 设置 我们使用 Tailwind 作为独立的 CLI 工具。更多信息可以参考官方指南。 注意:如果您在配备 Intel 处理…

    2025年12月24日
    000
  • 建立一个登录表单网站

    介绍 开发者们大家好!我很高兴分享我的最新项目:登录表单。该项目非常适合那些希望构建一个干净且功能齐全的登录界面的人,用户可以使用该界面来验证自己的身份。这是使用 html、css 和 javascript 增强前端开发技能的好方法,同时创建专业的用户身份验证体验。 项目概况 登录表单是一个网络应用…

    2025年12月24日
    000
  • 在 React/Nextjs 中添加深色和浅色主题支持

    在 react/next.js 中添加深色和浅色主题支持 概述 在本指南中,我们将引导您完成向 react 或 next.js 应用程序添加深色和浅色主题支持的步骤。这种方法将允许用户在主题之间切换,并且 ui 将相应更新。 先决条件 react 或 next.js 的基础知识。已设置 react …

    2025年12月24日
    000
  • 使用 React 构建 BMI 计算器

    使用 react 构建 bmi 计算器 介绍 体重指数(bmi)是一种广泛使用的指标,用于确定一个人在给定身高下是否拥有健康体重。在本博客中,我们将逐步介绍如何使用 react 创建一个简单但实​​用的 bmi 计算器。这个项目允许用户输入他们的体重和身高来计算他们的bmi,并根据结果提供分类。 项…

    2025年12月24日
    000
  • CSS 中的版式和字体样式

    讲座 4:css 中的版式和字体样式 在本次讲座中,我们将探讨如何使用 css 设置文本样式。版式是网页设计的一个重要方面,影响可读性、用户体验和整体美观。在本讲座结束时,您将了解如何在网站上应用各种字体样式并控制文本外观。 了解网页字体 网络字体允许您在网站上使用各种字体。您可以使用设备上预装的系…

    2025年12月24日
    000
  • 使用 API 和 JSON 的 Shopify Liquid REPL

    我非常兴奋 ? 分享我的新网站 Shopify Liquid REPL。 我最近看到 Taylor Page 关于 Shopify REPL (Read-Eval-Print-Loop) 的帖子,这促使我查看了该网站。检查网站的输出后,我创建了一个新版本,该版本集成了通过 API 输入的 JSON …

    2025年12月24日
    000
  • 响应式网页设计在当今数字环境中的重要性

    在快节奏、不断发展的技术世界中,网站已成为企业、组织和个人的数字店面。随着数十亿用户通过各种设备(从台式机和笔记本电脑到平板电脑和智能手机)访问互联网,网站仅仅在单一屏幕尺寸上看起来不错已经不够了。这就是响应式网页设计发挥作用的地方,确保所有设备上的无缝用户体验。但到底什么是响应式网页设计,为什么它…

    2025年12月24日
    000
  • 了解 CSS 盒模型:内容盒与边框盒、内联元素与块元素

    作为前端开发人员,了解 css 盒模型是make-or-break能够提供像素完美的布局。让我们深入讨论一下内联元素和块元素在两种盒模型类型(内容盒和边框盒)的上下文中的行为有何不同。 基础知识:盒子里有什么? 在详细介绍之前,有必要回顾一下盒模型是什么。页面上的每个元素都是一个盒子(是的,即使是那…

    2025年12月24日
    000
  • 建立一个温度转换器网站

    介绍 各位开发者大家好!我很高兴分享我的最新项目:实用的温度转换器。该项目非常适合那些希望通过处理用户输入、执行转换和动态更新 dom 来增强 javascript 技能的人。无论您是初学者还是经验丰富的开发人员,此温度转换器都是了解单位转换基础知识的绝佳项目。 项目概况 温度转换器是一款基于网络的…

    2025年12月24日 好文分享
    000
  • 工具和资源 [实时文档]

    CSS https://unsplash.com = 示例图片https://uifaces.co = 示例用户面部图像https://extract.pics/ = 从网站提取所有图像https://color.adobe.com/ = 上传渐变图像并获取十六进制颜色代码https://www.l…

    2025年12月24日
    000
  • 每个 UI 开发人员都应该知道的聪明的 CSS 行话

    简介:简洁 css 的力量 作为 ui 开发人员,您总是在寻找简化代码并创建更高效​​、更引人注目的设计的方法。 css(层叠样式表)是您的武器库中的基本工具,掌握它可以显着提高您的生产力和工作质量。在这篇博文中,我们将探索 15 个独特的 css 行话,它们可以彻底改变您设计网页的方法。 这些紧凑…

    2025年12月24日
    000
  • 如何在高对比度模式下自动调整颜色

    介绍 我最近收到一份错误报告,其中 svg 图标在高对比度模式下无法正确显示。在这篇文章中,我将分享对我有用的解决方案。 解决方案 在高对比度模式下,我使用canvastext系统颜色来自动调整图标的颜色。 .icon { mask-image: url(svg-link); background-…

    2025年12月24日
    000
  • 使无头组件易于设计

    无头组件只是一个无样式组件,还是还有更多内容? 网络已经通过要求定义样式来将样式与内容分开在 css 中而不是 html 中。这种架构允许每个网页都采用全局设计标准,无需定义任何特定于页面的样式。 随着网络演变成一个应用程序平台,开发人员寻找方法他们不断增长的代码库更易于维护。如今,事实上的策略是组…

    2025年12月24日
    000
  • 在 Reactjs 应用程序中查看过渡动画

    有一天,我想为网站创建快速从列表动画中删除项目的功能。这次跳过react transition group,尝试新的view transition,节省时间。 当很少有代码能做到这一点时,为什么要编写大量代码。 view transition api 仅适用于 chrome,但我不在乎。 关键是 d…

    2025年12月24日
    000
  • 姜戈顺风

    本教程演示如何在新项目中从头开始配置 django 和 tailwindcss。 django 设置 创建一个名为 .venv 的新虚拟环境。 # windows$ python -m venv .venv$ .venvscriptsactivate.ps1(.venv) $# macos/linu…

    2025年12月24日
    000
  • ⏰ 你的声音很重要 – CSS 调查现已开放!

    嘿? 本周五,Sprintfolio 将举办Designer + Dev Mixer。我正计划参加并且对此感到非常兴奋! 这将是与设计师和开发人员建立联系、交流见解并促进集体成长的绝佳机会。 我强烈推荐加入 – 完全免费!谁有兴趣? – 注册 享受 ? – Ada…

    2025年12月24日
    000
  • ust-Know 高级 Tailwind CSS 实用程序可增强开发体验

    tailwind css 以其实用性优先的方法而闻名,使开发人员能够直接在 html 中创建高度可定制的设计。除了基础知识之外,掌握高级实用程序还可以显着增强您的开发工作流程,使其更快、更高效。在这里,我们将探索每个开发人员都应该知道的六个高级 tailwind css 实用程序,并通过并排代码编辑…

    2025年12月24日 好文分享
    000
  • 使用 CSS 将渐变应用于文本。

    文字渐变 如今你可以在很多地方看到文本渐变等漂亮的技巧……但是呢?你有没有想过它们是如何制作的?今天就教你吧 .text-gradient { background: linear-gradient(-25deg, #5662f6 0%, #7fffd4 100%); col…

    2025年12月24日
    000
  • 黑暗主题的力量和性能优化:简单指南

    在当今的数字时代,用户体验是关键。增强这种体验的一种方法是在您的网站或应用程序上实施深色主题。它不仅看起来时尚,而且还可以提高现代设备的性能并节省电池寿命。让我们探索如何使用深色主题优化您的网站并提高性能。 为什么选择黑暗主题? 减少眼睛疲劳:深色主题对眼睛更温和,尤其是在弱光条件下。这使用户可以更…

    2025年12月24日 好文分享
    000
  • 掌握 CSS:终极 CSS 实践挑战课程

    通过 labex 的综合 css 实践挑战课程释放您作为 css 大师的真正潜力。这个精心设计的程序是您磨练 css 技能并将您的 web 开发能力提升到新高度的门户。 深入 CSS 的深处 无论您是经验丰富的 CSS 老手还是初露头角的 Web 开发人员,本课程都提供了丰富的实践练习宝库,可以挑战…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信