js动画和css3动画_js控制css动画

js动画和css3动画_js控制css动画动画css动画js动画css动画js动画

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用


Web动画的本质是元素状态改变造成的样式变更,CSS动画和JS动画的区别并不是由语言来决定的,而是由两者的特点和适用场景来判断的。

  • CSS动画简洁高效,提升交互体验而编写的代码可以轻松地和主要业务逻辑之间实现隔离,开发中建议优先使用;
  • 当你需要更丰富的缓动函数,多对象关联动画或是需要在动画执行的特定时间点关联一些其他的业务逻辑等需要细节控制的场景中,JS动画就会显得更加清晰且易维护

js动画

缺点:

  • JavaScript在浏览器的主线程中运行,而主线程中还有其它需要运行的JavaScript脚本、样式计算、布局、绘制任务等,对其干扰导致线程可能出现阻塞,从而造成丢帧的情况。
  • 代码的复杂度高于CSS动画

优点:

  • JavaScript动画控制能力很强, 可以在动画播放过程中对动画进行控制:开始、暂停、回放、终止、取消都是可以做到的。
  • 动画效果比css3动画丰富,有些动画效果,比如曲线运动,冲击闪烁,视差滚动效果,只有JavaScript动画才能完成
  • CSS3有兼容性问题,而JS大多时候没有兼容性问题

css动画

CSS动画通常指使用transition实现的过渡动画和使用animation来实现的关键帧动画。

南栀的博客—CSS动画

缺点:

  • 运行过程控制较弱,无法附加事件绑定回调函数。CSS动画只能暂停,不能在动画中寻找一个特定的时间点,不能在半路反转动画,不能变换时间尺度,不能在特定的位置添加回调函数或是绑定回放事件,无进度报告
  • 代码冗长。想用 CSS 实现稍微复杂一点动画,最后CSS代码都会变得非常笨重。

优点:

  • 浏览器可以对动画进行优化。
    • 浏览器使用与 requestAnimationFrame 类似的机制,requestAnimationFrame比起setTimeout,setInterval设置动画的优势主要是:1)requestAnimationFrame 会把每一帧中的所有DOM操作集中起来,在一次重绘或回流中就完成,并且重绘或回流的时间间隔紧紧跟随浏览器的刷新频率,一般来说,这个频率为每秒60帧。2)在隐藏或不可见的元素中requestAnimationFrame不会进行重绘或回流,这当然就意味着更少的的cpu,gpu和内存使用量。

    • 强制使用硬件加速 (通过 GPU 来提高动画性能)

  • 代码相对简单,性能调优方向固定
  • 对于帧速表现不好的低版本浏览器,CSS3可以做到自然降级,而JS则需要撰写额外代码

CSS动画流畅的原因:

  • 渲染线程分为main thread(主线程)和compositor thread(合成器线程)。
  • 如果CSS动画只是改变transform和opacity,这时整个CSS动画得以在compositor thread完成(而JS动画则会在main thread执行,然后触发compositor进行下一步操作)。
  • 在JS执行一些昂贵的任务时,main thread繁忙,CSS动画由于使用了compositor thread可以保持流畅。
  • 在主线程中,维护了一棵Layer树(LayerTreeHost),管理了TiledLayer。

  • 在compositor thread(合成器线程),维护了同样一颗LayerTreeHostImpl,管理了LayerImpl,这两棵树的内容是拷贝关系,因此可以彼此不干扰。

  • 当Javascript在main thread操作LayerTreeHost的同时compositorthread可以用LayerTreeHostImpl做渲染。

  • 当Javascript繁忙导致主线程卡住时,合成到屏幕的过程也是流畅的。

  • 为了实现防假死,鼠标键盘消息会被首先分发到compositor thread,然再到main thread。这样,当main thread繁忙时,compositor thread还是能够响应一部分消息。

  • 例如,鼠标滚动时,加入main thread繁忙,compositor thread也会处理滚动消息,滚动已经被提交的页面部分(未被提交的部分将被刷白)。

CSS动画比JS流畅的前提:

  • JS在执行一些昂贵的任务
  • 同时CSS动画不触发layout或paint
    在CSS动画或JS动画触发了paint或layout时,需要main thread进行Layer树的重计算,这时CSS动画或JS动画都会阻塞后续操作。

总结:

  • 如果动画只是简单的状态切换,不需要中间过程控制,在这种情况下,css动画是优选方案。它可以让你将动画逻辑放在样式文件里面,而不会让你的页面充斥 Javascript 库。
  • 设计很复杂的富客户端界面或者在开发一个有着复杂UI状态的 APP。那么你应该使用js动画,这样你的动画可以保持高效,并且你的工作流也更可控。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/181605.html原文链接:https://javaforall.net

(0)
上一篇 2022年10月15日 下午7:46
下一篇 2022年10月15日 下午7:46


相关推荐

  • 历年计算机二级Java考试试题及答案(完整版)

    历年计算机二级Java考试试题及答案(完整版)历年计算机二级 Java 考试试题及答案 完整版 一选择题 1 Java 语言程序设计试题及答案 每小题 1 分 共 40 小题 共 40 分 1 下列叙述中正确的是 A 一个算法的空间复杂度大 则其时间复杂度必定大 B 一个算法的空间复杂度大 则其时间复杂度必定小 C 一个算法的时间复杂度大 则其空间复杂度必定小 D 上述 3 种说法都不对 解析 算法的时间复杂度和空间复杂度是从不同的角

    2026年3月18日
    2
  • 实时语音识别(Qwen-ASR-Realtime)Python SDK-API参考

    实时语音识别(Qwen-ASR-Realtime)Python SDK-API参考

    2026年3月13日
    2
  • html自动写对联,HTML 实现网站对联广告位

    html自动写对联,HTML 实现网站对联广告位分享一个对联广告位的代码 网站通用 留着存放 哪天说不定用到了 html 代码 放到固定的位置 css 样式代码 index wall left width 350px height 528px position absolute top 120px margin left 366px background url https eimg smzdm com 201912 23 5e00

    2025年12月6日
    8
  • JAVA中ResourceBundle使用详解(一)

    JAVA中ResourceBundle使用详解(一)最近在看 HttpServlet 源码时候 碰到 ResourceBund 的使用 就此记录一下 一 ResourceBund 是啥这个类主要用来解决国际化和本地化问题 国际化和本地化是啥 另一篇文章有写 这里直接上用法 这个类获取的属性也是来自于 properties 属性文件 获取 properties 属性有两个方式 一是通过 Properties 二是通过 ResourceBund 方式 Pr

    2026年3月26日
    1
  • 计算机学科的发展方向

    计算机学科的发展方向计算机专业毕业后大致的工作方向是软、硬、网、图四大类尤其以软件、网络为现今的首选从岗位上分,又可以分为技术道路、营销道路两大方向if你选择作技术,then从现在开始,牢记:天道酬勤!!!if你选择软件技术then每天都要用大量的时间学习高级语言,绝对不能仅限于学校的安排。优秀的程序员都是大学阶段就已经自学得非常深入了。ifyou选择网络技术,那么

    2022年5月10日
    48
  • Linux 修改目录下所有文件权限

    Linux 修改目录下所有文件权限sudochmod777/目录/-R

    2022年7月26日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号