当前位置: 首页 > 编程日记 > 正文

CSS vs. JS Animation: 哪个更快

CSS vs. JS Animation: 哪个更快?

CSS vs. JS Animation: 哪个更快?

基于JavaScript的动画竟然已经默默地比CSS的transition动画快了?而且,Adobe和 Google竟然一直在发布可以媲美原生应用的富媒体移动站点?

这篇文章将会逐点讲解基于JavaScript的DOM动画库,比如Velocity.js和GSAP,是如何比jQuery和基于CSS的动画库高效的。

jQuery

让我们先从这个事实开始:JavaScript和jQuery被错误的混淆了。JavaScript的动画是快的,但是jQuery的动画慢。为什么?因为虽然jQuery很强大,但是它的目标从来不是为了成为一个高效的动画引擎。

  • jQuery不能避免布局震荡因为它的代码除了动画还提供了很多功能。

  • jQuery的内存消耗经常触发垃圾回收,导致动画卡住

  • jQuery使用setInterval而不是requestAnimationFrame (RAF)为了避免一些bug

注意,布局震荡引起了动画开始处的卡顿,垃圾回收导致了动画进行中的卡顿,RAF的缺席导致了帧率低。

实现的例子

避免布局震荡,包括简单地合并DOM查询和DOM更新:

var currentTop,currentLeft;/* 有布局震荡 */
currentTop = element.style.top; /* QUERY */
element.style.top = currentTop + 1; /* UPDATE */currentLeft = element.style.left; /* QUERY */
element.style.left = currentLeft + 1; /* UPDATE *//* 没有布局震荡 */
currentTop = element.style.top; /* QUERY */
currentLeft = element.style.left; /* QUERY */element.style.top = currentTop + 1; /* UPDATE */
element.style.left = currentLeft + 1; /* UPDATE */

发生在更新之后的查询会强制浏览器立马重新布局,并计算给出页面样式的计算值(把更新的影响考虑在内)。这对于运行于16ms间隔的动画来讲,会产生巨大的开销。

同样,实现RAF并不需要对既有代码改动很大。让我们来对比一下RAF的实现和setInterval的实现:

var startingTop = 0;/* setInterval: 每16ms运行一次来达到60fps (1000ms/60 ~= 16ms). */
setInterval(function() {/* 由于这里的代码会在1s内执行60次,所以我们把top属性每秒1单位的增长分成60份 */element.style.top = (startingTop += 1/60);
}, 16);/* requestAnimationFrame: 不管浏览器是否处于最优状态,都试图运行在60fps */
function tick () {element.style.top = (startingTop += 1/60);
}window.requestAnimationFrame(tick);

RAF极大限度地提高了动画的性能。而您只需要修改为数不多的代码。

CSS Transitions

CSS transitions的动画性能优于jQuery,它把动画的逻辑交给了浏览器本身。这会有助于:1)优化DOM交互和内存消耗以避免卡顿,2)在底层借助RAF的特性,3)强制硬件加速(借助GPU的能力来提高动画性能)。

然而,实际情况是,这些优化可以直接通过JavaScript来实现,GSAP已经致力于此多年。Velocity.js,一个新的动画引擎,不止借助于上述技术,还应用了其他方法--我们将很快探讨。

明白JavaScript动画可以媲美CSS动画库这一事实,只是我们计划的第一步。第二步是我们要明白JavaScript动画可以比CSS动画还快。

让我们从检查CSS动画库的缺陷开始:

  • Transitions的强制硬件加速是使GPU加速,然而这反而会导致GPU强压状况下动画的卡顿。这些影响在移动设备上更为严重。(特别地,这个卡顿是由于数据在浏览器的主线程和排序线程间传递的开销导致的。一些CSS属性,比如transforms和opacity,是不受这个开销影响的。)Adobe在这里阐述了这个问题。

  • Transitions在IE10以下有兼容问题, 这在PC端站点会很容易导致问题发生,因为IE8和IE9依然很流行。

  • 因为transitions并不是被JavaScript控制(它们只是被JavaScript触发),浏览器并不知道如何同步地使用JavaScript代码来操控优化transitions。

相反地:基于JavaScript的动画库,可以自己决定什么时候使用硬件加速,可以兼容所有版本的IE,并且它们非常适合批量动画优化。

我的建议是,当您只是开发移动站点,并且您的动画只包含简单的状态变化时,可以使用原生CSS transitions。在这种情况下,transitions算是一种高效并且原生的解决方案,并且可以把所有的动画逻辑只放在css中,避免了因为引入JavaScript库而导致页面臃肿。但是,如果您正在设计复杂的UI,或者正在开发具有状态UI的应用程序,请使用JavaScript动画库,它可以使您的动画保持高性能,使您的工作流程保持可控。特别是在管理CSStransitions方面做得很棒的一个库是 Transit

JavaScript Animation

Okay,所以JavaScript在性能上可以占上风。但是JavaScript究竟可以快多少呢?其实,它已经快到可以创建复杂的,通常只能用WebGL构建的3D animation demo。已经快到可以创建通常只能用Flash或者影效处理做到的multimedia teaser。已经快到可以创建通常只能用canvas构建的virtual world。

为了直观比较动画库的领先性能,包括Transit(内部使用CSS transitions),请查阅Velocity的文档,在VelocityJS.org。

依然存在问题:JavaScript究竟如何达到高性能?下面是基于JavaScript的动画库能实现的优化列表:

  • 为了减小布局震荡,将整个动画中涉及到DOM同步化到堆栈中。

  • 缓存链式调用中的属性值,以尽量减少DOM查询(它是影响DOM动画性能的致命弱点)的发生。

  • 在同一个跨同级元素调用中缓存单位转换比率(例如PX到%、em等)。

  • 当样式更新在视觉上不明显时,跳过更新。

回顾之前讲的布局震荡,Velocity.js利用这些最佳实践来缓存动画的结束值,这些值会被重用为之后动画的开始值,从而避免再次查询DOM元素的初始值:

$element/* 将元素向下滑动到视图中。 */.velocity({ opacity: 1, top: "50%" })/* 延迟1000ms,元素滑动出视图 */.velocity({ opacity: 0, top: "-50%" }, { delay: 1000 });

在上面的例子中,第二个Velocity自动知道它应该从opacity为1,top为50%开始。

浏览器最终可以自己执行很多相同的优化,但这样做将需要极大地限制开发人员编写动画代码的方式。因此,同样的原因,jQuery不使用RAF(见上文),浏览器也永远不会强加优化,即使这些优化只有非常小的可能会打破规范或偏离预期的行为。

最后,让我们来比较一下这两个JavaScript动画库(Velocity.js和GSAP)。

  • GSAP是一种快速、功能丰富的动画平台。Velocit是一个轻量级工具,可以极大地提高UI动画性能和工作流程。

  • GSAP需要许可费。Velocity是通过许MIT开源的。

  • 性能都很优异,GSAP和Velocity在真实项目中没有区别。

我的建议是:当您需要精确的控制(例如重映,暂停/恢复/搜索)、运动(例如Bezier曲线路径),或复杂的分组/排序时,使用GSAP。这些特性对于游戏开发和某些niche应用非常重要,但在Web应用程序的UI中并不常见。

Velocity.js

定位GSAP功能丰富,并不意味着Velocity功能单一。相反地,在压缩后只有7Kb的文件中,Velocity不仅提供了jQuery$.animate()的所有功能,而且提供了color animation,transforms,loops,easings,class animation和scrolling。

简而言之,Velocity是jQuery、jQuery UI和CSStransitions的最佳组合。

进一步,从方便的角度,Velocity在底层使用jQuery的$.queue()方法,因此可以无缝地与jQuery的$.animate(), $.fade()$.delay()函数交互。并且,由于Velocity的语法和$.animate()一致,您页面的代码不需要修改

让我们快速看一下Velocity.js。在基础动画上,Velocity和$.animate()一样:

$element.delay(1000)/* 使用Velocity的2000ms内改变元素top属性的动画*/.velocity({ top: "50%" }, 2000)/* 当上面Velocity动画执行完时,使用标准的jQuery方法来使元素淡出*/.fadeOut(1000);

在高级动画上,复杂的滚动场景和三维动画都可以创建——只需要两行简单的代码:

$element/* 在1000ms内,浏览器滚动到这个元素的顶部 */.velocity("scroll", 1000)/* 之后使元素绕着它的Y轴旋转360度。 */.velocity({ rotateY: "360deg" }, 1000);

结束语

Velocity的目标是保持领先的DOM动画性能和便捷。本文的重点是前者。请去VelocityJS.org学习更多关于后者的知识。

在我们结束之前,记得_*一个高性能的UI不仅仅是选择合适的动画库_。页面的其余部分也应该优化。从下面这些奇妙的Google话题中学习更多:

  • Jank Free

  • Rendering Without Lumps

  • Faster Websites

    本文转载自:众成翻译
    译者:凯小凯
    审校: betsey
    链接:http://www.zcfy.cc/article/4635
    原文:https://davidwalsh.name/css-js-animation

转载于:https://www.cnblogs.com/wwhhq/p/8157430.html

相关文章:

Squid下Http头信息优先级

no-cache>Expires>refresh_pattern>Last-Modified 也就是讲,最前面的最重要,前面的生效后,后面的基本就失效了. 另外squid本身就能对比Last-Modified,但根据我的测试,Etag还是会要向源服务器发送请求头,来确认etag的. ETag默认是需要向源网站…

阿里云PolarDB数据库将云原生进行到底!业内首次实现三层池化

10月20日,在2021云栖大会上,阿里云宣布自研云原生关系型数据库PolarDB重磅升级,实现内存池化、多主架构、HTAP实时分析等创新功能,进一步引领云原生数据库技术的持续创新。 阿里云智能数据库事业部总负责人李飞飞表示,…

zencoding实践

2019独角兽企业重金招聘Python工程师标准>>> .container<div class"container"></div>.wrap>ul>.list>.site <div class"wrap"><ul><li class"list"><div class"site"></…

第三期 OSI七层中第一层 物理层

物理层1、信号1&#xff09;信息2&#xff09;数据3&#xff09;信号&#xff1a;信息传递的媒介 4&#xff09;信号的分类&#xff1a;模拟信号&#xff1a;连续变化的物理量。数字信号&#xff1a;不连续的物理量&#xff0c;信号参数也不连续变化&#xff0c;高低固定。5&am…

Squid的refresh_pattern配置

refresh_pattern 大概是 squid 最有意思但最不好懂的配置参数了。 记住refresh_pattern 只对后端没设置Expires过期时间的页面起作用&#xff0c;比如论坛页面&#xff1b;而对类似apache mod_expires 设置过的页面不起作用。 说明之前&#xff0c;先将个概念LM&#xff0c;L…

阿里云发布第四代神龙架构云计算首次进入5微秒时延时代

10月20日&#xff0c;2021云栖大会上&#xff0c;阿里云宣布推出第四代神龙架构&#xff0c;这是飞天云操作系统新一代虚拟化技术&#xff0c;首次搭载全球唯一的大规模弹性RDMA加速网络&#xff0c;网络延迟整体降低80%以上。神龙4.0带来的计算架构革新&#xff0c;将云计算首…

【微服务】Spring-Boot整合Consul (自定义服务配置及健康检查)

为什么80%的码农都做不了架构师&#xff1f;>>> 目的 上文提到仅使用discovery包自带的注册功能进行服务注册&#xff0c;但是由于监控的是 /health&#xff0c;使用actuator实现自由度不够&#xff0c;并且有些低级异常可能不完全影响服务运行&#xff0c;但状态依…

Apache URL重定向避免网址结尾斜线问题

结尾斜线问题描述: 每个网主都曾受到结尾斜线问题的折磨&#xff0c;若在URL中没有结尾斜线&#xff0c;服务器就会认为URL无效并返回错误&#xff0c;因为服务器会根据/~quux/foo去寻找foo这个档案&#xff0c;而非显示这个目录。其实很多时候&#xff0c;这问题应留待用户自己…

16:00面试,16:08就出来了 ,问的实在是太...

从外包出来&#xff0c;没想到算法死在另一家厂子自从加入这家公司&#xff0c;每天都在加班&#xff0c;钱倒是给的不少&#xff0c;所以也就忍了。没想到8月一纸通知&#xff0c;所有人不许加班&#xff0c;薪资直降30%&#xff0c;顿时有吃不起饭的赶脚。好在有个兄弟内推我…

提前了解客户背景很有必要

2019独角兽企业重金招聘Python工程师标准>>> 最近&#xff0c;公司与某电商展开了合作&#xff0c;我司将为该电商提供提供一套广告解决方案。我有幸参与到这个项目&#xff0c;了解该电商的需求&#xff0c;思考公司的产品是否能够和如何满足这些需求。近日&#x…

wamp多站点访问设置

1、修改C:\Windows\System32\drivers\etc\hosts文件 2、修改httpd.conf和httpd-vhosts.conf文件 3、重启apache转载于:https://www.cnblogs.com/liusirdotme/p/8177386.html

满足极高读写性能需求的Key-Value数据库

满足极高读写性能需求的Key-Value数据库 高性能Key-Value数据库的主要特点就是具有极高的并发读写性能&#xff0c;Redis&#xff0c;Tokyo Cabinet&#xff0c; Flare&#xff0c;这3个Key-Value DB都是用C编写的&#xff0c;他们的性能都相当出色&#xff0c;但出了出色的性…

QQ群功能设计与心理学

2019独角兽企业重金招聘Python工程师标准>>> 刚刚在一个Java技术交流群&#xff0c;发了个 "博客投票"的广告。 群主两眼一黑&#xff0c;瞬间就把我给干掉了。 看到QQ给出的系统消息&#xff0c;发现QQ群的一个功能做得很不错。 大家注意到&#xff0c;右…

龙蜥降世,神龙升级,阿里云投入 20 亿发力操作系统

作者 | 贾凯强、伍杏玲 出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;10 月 20 日&#xff0c;阿里巴巴云栖大会继续在杭州进行&#xff0c;与开幕第一天的主论坛不同&#xff0c;第二天活动的主论坛更加聚焦与技术领域和技术实践。20 日上午&#xff0c;阿里…

35.2. Subversion 版本控制

subversion 初始化trunk branches releases tags svn co svn://127.0.0.1/document cd project mkdir trunk mkdir tags mkdir branches mkdir releases svn ci -m "Initialized empty subversion repository in your_project"创建docbook文档&#xff0c;安排章节…

使用卷积神经网络预防疲劳驾驶事故

作者|小白来源|小白学视觉疲劳驾驶&#xff1a;一个严重的问题美国国家公路交通安全管理局估计&#xff0c;每年有 91,000 起车祸涉及疲劳驾驶的司机&#xff0c;造成约50,000 人受伤和近 800 人死亡。此外&#xff0c;每 24 名成年司机中就有 1 人报告在过去 30 天内在驾驶时睡…

详解Apache下.htaccess文件常用配置

.htaccess文件是Apache服务器中最常用的一个配置文件&#xff0c;它负责相关目录下的网页配置。通过htaccess文件&#xff0c;可以帮我们实现&#xff1a;网页301重定向、自定义404错误页面、改变文件扩展名、允许/阻止特定的用户或者目录的访问、禁止目录列表、配置索引入口等…

hadoop HDFS常用文件操作命令

命令基本格式: hadoop fs -cmd < args >1.ls hadoop fs -ls /列出hdfs文件系统根目录下的目录和文件 hadoop fs -ls -R /列出hdfs文件系统所有的目录和文件 2.put hadoop fs -put < local file > < hdfs file >hdfs file的父目录一定要存在&#xff0c;否则…

php缓存技术总结

全页面静态化缓存也就是将页面全部生成html静态页面&#xff0c;用户访问时直接访问的静态页面&#xff0c;而不会去走php服务器解析的流程。此种方式&#xff0c;在CMS系统中比较常见&#xff0c;比如dedecms&#xff1b;一种比较常用的实现方式是用输出缓存&#xff1a;Ob_st…

两个使用 Pandas 读取异常数据结构 Excel 的方法,拿走不谢!

作者 | 周萝卜来源 | 萝卜大杂烩通常情况下&#xff0c;我们使用 Pandas 来读取 Excel 数据&#xff0c;可以很方便的把数据转化为 DataFrame 类型。但是现实情况往往很骨干&#xff0c;当我们遇到结构不是特别良好的 Excel 的时候&#xff0c;常规的 Pandas 读取操作就不怎么好…

ArcEngine中的缩放地图

在ArcEngine地图操作中&#xff0c;缩放地图的功能经常用到&#xff0c;这里做一个小结。 缩放地图一般可分为以下几种情况&#xff1a; 1.缩放地图&#xff1a;与放大地图相对&#xff0c;一般是手动绘制区域或固定比例缩放&#xff0c;可调用命令或Expand函数来&#xff1b; …

【小记】批处理FOR循环中的参数/D

2019独角兽企业重金招聘Python工程师标准>>> 官方说明 FOR /D %variable IN (set) DO command [command-parameters] 如果集中包含通配符&#xff0c;则指定与目录名匹配&#xff0c;而不与文件名匹配。 栗子 REM Eg1.bat REM 与此批处理同级的目录名称全部打印出来…

php 的opcode缓存apc以及其安装

先说说php程序的执行流程吧&#xff0c;说明了这个&#xff0c;才好开始我们的优化之旅。 客户端&#xff08;譬如浏览器&#xff09; —》请求Get hello.php —-》cgi服务器接&#xff08;譬如apache&#xff09;收到请求&#xff0c;根据配置寻找php的处理程序&#xff08;…

1024 程序员节专题论坛来袭,权威解读 MindSpore、CANN 5.0 特性和 HCIA MDC 开发者认证...

“授人以鱼不如授人以渔”&#xff0c;一句古话中蕴含的发展真理&#xff0c;我们将其套用到如今炽手可热的 AI 领域之上会发现无比适用。2018 年&#xff0c;华为提出了普惠 AI 的概念&#xff0c;降低 AI 开发门槛&#xff0c;让 AI 开发者获取能力&#xff0c;让技术走近每一…

leetcode之Reorder List

Given a singly linked list L: L0→L1→…→Ln-1→Ln,reorder it to: L0→Ln→L1→Ln-1→L2→Ln-2→… You must do this in-place without altering the nodes values. For example,Given {1,2,3,4}, reorder it to {1,4,2,3}. 这道题分三步&#xff1a; 1&#xff1a;首先将…

shiro多realm验证之——shiro实现不同身份使用不同Realm进行验证(转)

转自: http://blog.csdn.net/xiangwanpeng/article/details/54802509 (使用特定的realm实现特定的验证) 假设现在有这样一种需求&#xff1a;存在两张表user和admin&#xff0c;分别记录普通用户和管理员的信息。并且现在要实现普通用户和管理员的分开登…

前端开发中的性能那点事

前端开发中的性能那点事&#xff08;一&#xff09;巧用xdebug 前言&#xff1a; 在我们平时的php开发中&#xff0c;一个大的项目经过长时间的积累以后你会发现性能越来越慢&#xff0c;而性能到底消耗在了什么地方&#xff0c;常常是一个令人头疼的问题&#xff0c;function…

运动目标检测ViBe算法

一、运动目标检测简介 视频中的运动目标检测这一块现在的方法实在是太多了。运动目标检测的算法依照目标与摄像机之间的关系可以分为静态背景下运动检测和动态背景下运动检测。先简单从视频中的背景类型来讨论。 静态背景下的目标检测&#xff0c;就是从序列图像中…

急缺开源人才怎么办?来看看大厂和高校怎么解决

开源&#xff0c;是数字中国建设的热点领域之一&#xff0c;也是数字经济时代的基础。在我国加速实现数字化转型的背景下&#xff0c;开源已经从个人行为、企业行为发展到了国家新基建的战略层面。它打破传统的组织架构与商业教条&#xff0c;彻底颠覆了工业经济时代的运转逻辑…

经验分享 | Burpsuite抓取非HTTP流量

使用Burp对安卓应用进行渗透测试的过程中&#xff0c;有时候会遇到某些流量无法拦截的情况&#xff0c;这些流量可能不是HTTP协议的&#xff0c;或者是“比较特殊”的HTTP协议(以下统称非HTTP流量)。遇到这种情况&#xff0c;大多数人会选择切换到Wireshark等抓包工具来分析。下…