Web Animations: why and when to use them, and some demos we wrote
There's been much talk of Web Animations for a long time but it wasn't quite clear what that meant exactly, or even when could we get that new thing working in our browsers, or whether we should actually care about it.
A few weeks ago, Belén, Sam and me met to brainstorm and build some demos to accompany the Firefox 48 release with early support for Web Animations. We had been asked with very little time, but we reckoned we could build at least a handful of them.
We tried to look at this from a different, pragmatic perspective.
Most graphic API demos tend to be very technical and abstract, which tends to excite graphics people but mean nothing to web developers. The problem web developers face is not making circles bounce randomly on the screen, it is to display and format text on screen, and they have to write CSS and work with designers who want to play a bit with the CSS code to give it as much 'swooosh' as they envision. Any help we can provide to these developers so they can evaluate new APIs quickly and decide if it's going to make their work easier is going to be highly appreciated.
So our demos focused less on moving DIVs around and more on delivering value, either to developers by offering side by side comparisons (JS vs CSS code and JS vs CSS performance) or to end users with an example of an style guide where designers can experiment with the animation values in situ, and another example where the user can adjust the amount of animation to their liking—we see this as a way of using the API for improving accessibility.
You can also download all the demos from the repo:
git clone https://github.com/mozdevs/Animation-examples.git
And should you use CSS or should you use JS? The answer is: it depends.
Let's look at the same animation defined with CSS and JS, taken straight from the CSS vs JS demo:
CSS:
.rainbow {
animation: rainbow 2s alternate infinite;
}
@keyframes rainbow {
0% { background: #ff004d; }
20% { background: #ff77ab; }
50% { background: #00e756; }
80% { background: #29adff; }
100% { background: #ff77ab;}
}
JavaScript:
let el = document.querySelector('.rainbow');
el.animate([
{ background: '#ff004d', offset: 0 },
{ background: '#ff77ab', offset: 0.20 },
{ background: '#00e756', offset: 0.5 },
{ background: '#29adff', offset: 0.80 },
{ background: '#ff77ab', offset: 1 }
], {
duration: 2000,
direction: 'alternate',
iterations: Infinity
});
As you can see, this is fairly similar.
CSS's syntax for animations has been with us for a while. We know how it works, there is good support across browsers and there is tooling to generate keyframes. But once the keyframes are defined, there's no going back. Modifying them on the fly is difficult unless you start messing with strings to build styles.
This is where the JS API proves its worth. It can tap into live animations, and it can create new animations. And you can create animations that are very tedious to define in CSS, even using preprocessors, or just plain impossible to predict: imagine that you want custom colour animations starting from an unknown colour A and going to another unknown colour B. Trying to pregenerate all these unknown transitions from the beginning would result in an enormous CSS file which is hard to maintain, and would not even be as accurate as a newly created animation could be.
There's another advantage of using the Web Animations API versus animating with a library such as tween.js—the API is hardware accelerated and also runs on the compositor thread, which means incredibly smooth performance and pretty much perfect timing. When you animate DOM elements using JavaScript you have to create lots of strings to set the style property of these DOM elements. This will eventually kick a pretty massive Garbage Collector, which will make your animations pause for a bit: the dreaded jank!
Finally another cool feature of these native animations is that you can inspect them using the browser developer tools. And you can scrub back and forth, change their speed to slow them down or make them faster, etc. You cannot tap into JS-library-defined animations (e.g. tween.js) unless there's support from the library such an inspector, etc.
Essentially: Web Animations cheat by running at browser level. This is the best option if you want to animate DOM elements. For interpolating between plain values (e.g. a three.js object position vector x, y, z properties) you should use tween.js or similar.
If you want to know more here's an article at Hacks talking about compositors, layers and other internals, and inspecting with DevTools. And with plenty of foxes!
The full API isn't implemented in any browser yet, but both Firefox and Chrome stable have initial support already. There's no excuse: start animating things already! I'm also excited that both browsers shipped this early support more or less simultaneously—makes things so much easier for developers.
With mega thanks to Belén for pushing this forward and to Sam for going out of his internship way to help us with this 🙌🏼