search
HomeWeb Front-endFront-end Q&AWhat is the difference between css3 animation and js animation

Difference: 1. The control ability of js animation is stronger than that of css3 animation; 2. The effect of js animation is richer than that of css3 animation; 3. In most cases, js animation does not have compatibility issues, while css3 animation has compatibility Problem; 4. The complexity of js animation is higher than that of css3 animation.

What is the difference between css3 animation and js animation

The operating environment of this tutorial: Windows 7 system, CSS3&&javascript version 1.8.5, Dell G3 computer.

JS Animation

Advantages:

  • js animation control ability is strong, you can finely control the animation, start and pause during the animation process , termination and cancellation can all be done

  • The animation effects are richer than css3 animation, such as curve movement, impact flashing, parallax scrolling effect, only js animation can complete

  • JS animations have no compatibility issues in most cases, while CSS3 animations have compatibility issues

Disadvantages

  • The complexity of js animation is higher than that of css3

  • js is executed in the main thread of the animation browser, and the main thread also has other javaScript scripts, style calculation, layout, drawing tasks, etc., for Its interference may cause blocking and frame loss.

  • js animation often requires frequent manipulation of the css properties of the DOM to achieve visual animation effects. At this time, the browser must continue to execute Redrawing and reflowing consume a lot of performance, especially on mobile terminals where the memory allocated to the browser is not so generous.

CSS3 animation

Advantages:

1. In some cases, the browser can optimize the animation. Why do you say that in some cases, because it is Conditional:

  • In a browser based on Chromium
  • At the same time, CSS animation does not trigger layout or paint, but CSS animation or JS animation triggers paint or layout At this time, the main thread is required to recalculate the Layer tree. At this time, CSS animation or JS animation will block subsequent operations.

    In the main thread, a Layer tree (LayerTreeHost) is maintained and TiledLayer is managed. In the compositor thread, the same LayerTreeHostImpl is maintained and LayerImpl is managed. The contents of these two trees are copy relationship. Therefore, they can not interfere with each other. When Javascript operates LayerTreeHost in the main thread, the compositor thread can use LayerTreeHostImpl for rendering. When Javascript is busy and the main thread is stuck, the process of compositing to the screen is also smooth.
    In order to prevent suspended animation, mouse and keyboard messages will be distributed to the compositor thread first, and then to the main thread. In this way, when the main thread is busy, the compositor thread can still respond to some messages. For example, when the mouse is scrolling and the main thread is busy, the compositor thread will also process the scrolling messages and scroll the page parts that have been submitted (the unsubmitted parts will be whitewash).

2. Some effects can be forced to use hardware acceleration (to improve animation performance through the GPU)

Disadvantages

  • The control of the running process is weak. CSS3 animation can only control the pause and continuation of animation in certain scenarios, and callback functions cannot be added at specific locations.

  • The code is lengthy. If you want to use CSS to implement slightly more complex animations, the CSS code will become very cumbersome in the end.

The premise that css animation is smoother than js animation

  • js is performing some complex tasks
  • css animation is less or does not trigger pain and layout, that is, redrawing and rearranging, such as css animation generated by changing the following properties
    • backface-visibility
    • opacity
    • perspective (setting element view)
    • perspective-origin
    • transfrom
  • Some attributes can enable 3D acceleration and GPU hardware acceleration, such as when using transform's translateZ for 3D transformation
  • In browsers based on Chromium, this seems to be optimized by the kernel. When the css animation knowledge changes transfrom and opacity, the entire CSS animation can be completed in the compositor thread (while the JS animation will be executed in the main thread), so that css Animation rendering does not affect the main thread.

Summary

Returning to daily development, when there is a need for animation, the first consideration must be whether it can be realized as much as possible. If both CSS animation and JS animation can be realized, we will have to weigh the issue of which performance is better based on the summary above. In short, CSS animation is not necessarily better than JS animation. It depends on the specific needs and business scenarios.

Learning video sharing: css video tutorial, javascript learning tutorial

The above is the detailed content of What is the difference between css3 animation and js animation. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
CSS动画指南:手把手教你制作闪电特效CSS动画指南:手把手教你制作闪电特效Oct 20, 2023 pm 03:55 PM

CSS动画指南:手把手教你制作闪电特效引言:CSS动画是现代网页设计中不可或缺的一部分。它可以为网页带来生动的效果和交互性,并提升用户体验。在本指南中,我们将详细介绍如何使用CSS来制作闪电特效,以及提供具体的代码示例。一、创建HTML结构:首先,我们需要创建一个HTML结构来容纳我们的闪电特效。我们可以使用一个<div>元素来包裹闪电特效,并为

CSS动画教程:手把手教你实现翻页特效CSS动画教程:手把手教你实现翻页特效Oct 24, 2023 am 09:30 AM

CSS动画教程:手把手教你实现翻页特效,需要具体代码示例CSS动画是现代网站设计中必不可少的一部分。它可以为网页增添生动感,吸引用户的注意力,并且提高用户体验。其中一种常见的CSS动画效果就是翻页特效。在这篇教程中,我将带领大家一步一步实现这个引人注目的效果,并提供具体的代码示例。首先,我们需要创建一个基本的HTML结构。代码如下:<!DOCTYPE

CSS动画指南:手把手教你制作眨眼特效CSS动画指南:手把手教你制作眨眼特效Oct 20, 2023 pm 03:24 PM

CSS动画指南:手把手教你制作眨眼特效眨眼特效是一种常见的CSS动画效果,通过简单的代码实现,可以带来生动独特的效果。本文将为你提供一份手把手的指南,教你如何使用CSS制作眨眼特效,并提供具体的代码示例。创建HTML结构首先,我们需要创建一个HTML结构,用于展示眨眼特效。代码如下:<!DOCTYPEhtml><html>&

利用CSS实现图片展示特效的技巧和方法利用CSS实现图片展示特效的技巧和方法Oct 24, 2023 pm 12:52 PM

利用CSS实现图片展示特效的技巧和方法无论是网页设计还是应用开发,图片展示都是非常常见的需求。为了提升用户体验,我们可以利用CSS来实现一些炫酷的图片展示特效。本文将介绍几种常用的技巧和方法,并提供相应的代码示例,帮助读者快速上手。一、图片缩放特效缩放鼠标悬浮效果当鼠标悬浮在图片上时,通过缩放效果可以增加交互性。代码示例如下:.image-zoom{

CSS动画教程:手把手教你实现脉冲特效CSS动画教程:手把手教你实现脉冲特效Oct 21, 2023 pm 12:09 PM

CSS动画教程:手把手教你实现脉冲特效,需要具体代码示例引言:CSS动画是网页设计中常用的一种效果,它可以为网页增添活力和视觉吸引力。本篇文章将带您深入了解如何利用CSS实现脉冲特效,并提供具体的代码示例教您一步步完成。一、了解脉冲特效脉冲特效是一种循环变化的动画效果,通常用在按钮、图标或其他元素上,使其呈现出一种跳动、闪烁的效果。通过CSS的动画属性和关键

利用CSS实现鼠标悬停时的抖动特效的技巧和方法利用CSS实现鼠标悬停时的抖动特效的技巧和方法Oct 21, 2023 am 08:37 AM

利用CSS实现鼠标悬停时的抖动特效的技巧和方法鼠标悬停时的抖动特效可以为网页添加一些动感和趣味性,吸引用户的注意力。在这篇文章中,我们将介绍一些利用CSS实现鼠标悬停抖动特效的技巧和方法,并提供具体的代码示例。抖动的原理在CSS中,我们可以使用关键帧动画(keyframes)和transform属性来实现抖动效果。关键帧动画允许我们定义一个动画序列,通过在不

CSS实现淡入淡出图片效果的技巧和方法CSS实现淡入淡出图片效果的技巧和方法Oct 20, 2023 pm 04:25 PM

CSS实现淡入淡出图片效果的技巧和方法在网页设计中,图片的展示是非常重要的一部分。为了提升用户体验,我们经常会使用一些动态效果来增加页面的吸引力。其中,淡入淡出效果是一种常见且优雅的动画效果,可以让页面显得流畅和有活力。本文将介绍使用CSS实现淡入淡出图片效果的技巧和方法,并提供具体的代码示例供参考。一、使用CSS的opacity属性实现淡入淡出效果CSS的

CSS动画教程:手把手教你实现淡入淡出效果CSS动画教程:手把手教你实现淡入淡出效果Oct 18, 2023 am 09:22 AM

CSS动画教程:手把手教你实现淡入淡出效果,包含具体代码示例在网页设计和开发中,动画效果可以让页面更加生动和吸引人。而CSS动画是一种简单而且强大的方式来实现这种效果。本篇文章将手把手教你如何使用CSS来实现淡入淡出效果,并提供具体的代码示例供参考。一、淡入效果淡入效果是指元素从透明度为0逐渐变为透明度为1的效果。以下是实现淡入效果的步骤和代码示例:步骤1:

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Hot Tools

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

DVWA

DVWA

Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.