Animate me less or more helps you out generating a cross-browser and completely valid @keyframes & animation's css code, without hacks.
Why? I usually prefer SCSS but since less is better supported in wordpress (less-php, wp-less) and I wanted to simplify this huge css to recreate this nice menu I though to do this, to me useful, mixin.
First two things
- Import the
animate-mi.less
file in your project (the code is kinda of minified, there's no special reason for this, but even if I haven't tested it, it might result in slightly faster compile process due to to the length of the variables names, but probably the advantage is really small, anyway at least it looks more compat and it takes less space). You can always use theanimate-mi.dev.less
to take a look at the source code in a more readable way, and maybe improve it or customize your version. - Remember always to declare (once is enough of course) this variable somewhere in your less files, setting the value accordingly with the compiler you use (
'js'
or'php'
are the only ones supported):
@lesscompiler: 'js';
Then you can write an animation in these ways:
- declaring the keyframes and the css selector which will contain the animation
.animate-me(CrossFade; false; '.cross-fade';
'0%, 100%'; 'opacity: .4'
);
- declaring also the animation properties you want (like in plain css)
.animate-me(CrossFade; 3s infinite linear; '.cross-fade';
'0%, 100%'; 'opacity: .4'
);
- just declaring the keyframes (withous css selector)
.animate-me(TrafficLight; false; false;
0%; 'background: red';
20%; 'background: yellow';
50%; 'background: green'
);
- if you want to animate properties that need to be prefixed you can put
%s
in front of the propertyName, without spaces in between, it will be replaced with the right vendor prefix only inside the relative vendor keyframe declaration
.animate-me(SimpleAnimation; false; '.simple-animation';
0%; '%stransform: translateZ(0%) rotateY(0deg)';
100%; '%stransform: translateZ(100%) rotateY(360deg)'
);
- you can put a lot of keyframes steps (percentages), but there's a limit: 10 steps/percentages maximum (if you write
'10%, 45%'
it count as one).
.animate-me(ComplexAnimation; 0.4s ease; '.complex-animation';
'50%, 100%'; '%stransform: translateZ(-250px) rotateY(30deg)';
70%; '%stransform: translateZ(-250px) rotateY(30deg); opacity: .5';
30%; '%stransform: translateZ(-250px) rotateY(30deg); opacity: .5';
80%; '%stransform: translateZ(-250px) rotateY(30deg); opacity: 1'
);
As said before this mixin doesn't produce hacks, at least if the less compiled with the original javascript compiler,
- The only kind of 'hack' that you'll find in the generated css are
/* comments */
. This is normally not a problem, since they are ignored by the browsers. - Anyway you probably always minify your css in production so the generated comments will be stripped out.
- The generated code is completely valid and linted css: try it with this useful tool.
There are some differences if you compile your less code through the less-php port by @leafo
- the generated css have longer comments
- less readable formatting (linebrakes, spaces..) but since you minify it, who cares
- you'll find the code
.hack { visibility: visible }
at the end of all the rules of every animation only if the mixin is used without a css selector (so with false) on the third parameter
this piece of .less code...
@lesscompiler: 'js';
.animate-me(CrossFade; false; '.cross-fade';
'0%, 100%'; 'opacity: .4'
);
...will output this css code with the JS COMPILER:
@-moz-keyframes CrossFade {
0%, 100% {
opacity: .4; /* {
/**/
}
}
@-webkit-keyframes CrossFade {
0%, 100% {
opacity: .4; /* {
/**/
}
}
@-o-keyframes CrossFade {
0%, 100% {
opacity: .4; /* {
/**/
}
}
@keyframes CrossFade {
0%, 100% {
opacity: .4; /* {
/**/
}
} .cross-fade {
-moz-animation: CrossFade;
-webkit-animation: CrossFade;
-o-animation: CrossFade;
animation: CrossFade;
}
...and this css code with the PHP COMPILER:
@lesscompiler: 'php';
@-moz-keyframes CrossFade { 0%, 100% { opacity: .4; /* {
commented: 0;
}
*/} }@-webkit-keyframes CrossFade { 0%, 100% { opacity: .4; /* {
commented: 0;
}
*/} }@-o-keyframes CrossFade { 0%, 100% { opacity: .4; /* {
commented: 0;
}
*/} }@keyframes CrossFade { 0%, 100% { opacity: .4; /* {
commented: 0;
}
*/} } .cross-fade {
-moz-animation: CrossFade;
-webkit-animation: CrossFade;
-o-animation: CrossFade;
animation: CrossFade;
}
Try it yourself here:
- the jsCompiler
- the phpCompiler
These are the parameters you pass to the mixin:
name | properties | css selector | percentage | properties |
---|---|---|---|---|
theAnimationName required |
false can be false |
false can be false |
number% without quotes |
%s in front of the css property to add the vendor prefix |
0.5s see here for all the animation properties |
'.css-animation-selector' must be quoted |
'15%, 75%' put quotes when you have more than one percentage |
can be one or as many properties... | |
4s ease 1s infinite |
'from, to' put quotes when you want to use the 'from/to' notation |
...divide them with a semicolomn, like css. |
Thanks to these threads on stackoverflow: