CSS animation notes

Animation is often used in my work, but I often forget how to use animation and often confuse animation, transform, transition and translate. So I found it necessary to write it down again.

transform

MDN: CSS’s Transform property allows you to rotate, scale, tilt, or translate a given element. This is done by modifying the coordinate space of the CSS visual formatting model.

This shows that the transform property is just a static visual change to a given element and has no animation properties. But when we use animation, we can do a lot of things with the transform property, which is an essential part of the animation.

translate

Translate is actually an attribute value, belonging to the transform attribute. The translate(x,y) method moves an element from its current position, based on the given left and top position parameters. Achieve 3D movement with translate3D (X, Y, Z)

For Transform and translateZ, here’s a post by Zhang Xinxu: Ok, CSS3 3D Transform, but that’s it!

transition

The MDN: transition property is a shorthand property for transition-property, transition-duration, transition-timing-function, and transition-delay.

The transition attribute, which means a transition from one attribute value to another. For example:

p{ width:100px; transition:width 1s easy-in-out; } p:hover{ width:200px; } When the mouse hover over the p element, the width changes from 100px to 200px, taking 1s, and the time curve is easy-in-outCopy the code

And of course transition can work with a lot of properties, separated by a comma, or it can be all, so it works with all properties.

The disadvantages of transition are also obvious, that is, it is impossible to manipulate the animation effects of elements in finer granularity, and there must be trigger conditions, such as suspension or JS.

animation

MDN:CSS animation properties are animation-name, animation-duration, animation-timing-function, animation-delay, A shorthand form of the animation-rotund-count, animation-direction, animation-fill-mode, and animation-play-state properties.

Animation-name: used to call the animation defined by @keyframes, which is the same as the animation name defined by @keyframes

Animation-duration: Specifies the duration for which the element plays the animation

Animation-timing-function: specifies the speed curve for the speed effect, which is the transformation rate for each small animation in the time range

Animation-delay: Defines the time to wait before the browser starts executing the animation. It is the time to wait before the animation executes

Animation-rotund-count: Defines the number of times an animation is to be played.

Animation-direction: Sets the direction of the animation: Normal (in chronological order),reverse(running in the opposite direction of the time axis),alternate(alternating),alternate-reverse(animation runs first in the opposite direction and then in the positive direction, and continues to run alternately)

12. animation-fill-mode: controls the style of an element at the end of the animation, with four values: None (back to the state before the animation starts), forward (animation stays at the end after the animation ends), backwords(animation goes back to the state of frame 1), Both (rotate forwards and backwards according to animation-direction), make sure not to conflict with rotlecount (animations are executed unlimited times)

● Animation-play-state: controls the playback state of an element’s animation, by which the animation can be paused and resumed. Two values: running and paused.

Definition of animation:

@keyframes slidein { from { transform: scaleX(0); } to { transform: scaleX(1); }}Copy the code

Of course, a finer percentage of force can also be used to define the dynamic effect

CSS Hardware Acceleration

At present, most computer graphics cards support hardware acceleration, yes, the animation is more smooth, then the specific use is:

 transform: translate3d(0, 0, 0);
Copy the code