- Cómo manejar varias transiciones en CSS3
- Transiciones en CSS: transition-property y transition-duration
- Transiciones en CSS: Cómo controlar el ritmo y el inicio
En esta ocasión voy a mostrar como emplear varias transiciones en CSS sobre un mismo elemento. Sin embargo, antes de entrar en materia, será recomendable saber cómo funciona el atajo transition para que en caso de realizar varias transiciones, no quede un CSS con tantas líneas.
El atajo transition
A medida que he explicado las diferentes propiedades de transition, habrás observado que tengo en cuenta los prefijos de los navegadores. Esto hace que si usamos una transición con todas sus propiedades quedaría un buen churro.
Para ello podemos usar la propiedad transition y asignar los valores en función de un orden:
- El primer valor sería la propiedad afectada de la transición (transition-property).
- Tendría la duración (transition-duration).
- El ritmo (transition-timing-function)
- Y cuánto tiempo tarda en iniciar la animación (transition-delay).
No es necesario especificar todos los valores, de hecho el siguiente ejemplo no va a contar con un delay.
1 2 3 4 |
-webkit-transition: -webkit-transform 3s ease-out; -moz-transition: -moz-transform 3s ease-out; -o-transition: -o-transform 3s ease-out; transition: transform 3s ease-out; |
Cómo puedes observar, tengo en cuenta la compatibilidad de los navegadores y una transición en pocas líneas. Tener un CSS más compacto te ayudará a encontrar más fácilmente lo que quieras modificar.
Cómo manejar varias transiciones
Todas las propiedades referidas con transiciones permiten realizar varias en una misma llamada. Por ejemplo, podemos cambiar el fondo de un elemento mientras aumenta su tamaño y modifica su rotación.
En el siguiente ejemplo vamos a crear un div que cambiará de color y tamaño al mismo tiempo. Como vamos a modificar el elemento mediante transform y background, será preciso indicarlo en el transition-property.
1 |
transition-property: transform, background-color; |
A continuación indicamos la duración. Si sólo indicamos un valor, la duración será la misma para los 2. En caso contrario podemos indicarle cuanto durará cada transición por si queremos que una sea más rápida que la otra.
1 |
transition-duration: 0.2s, 0.1s; |
Y finalmente le indicamos el ritmo de la transición. Sucede lo mismo que con la propiedad duration, si indicamos uno, será empleado por las 2 transiciones.
1 |
transition-timing-function: ease-out, linear; |
Ahora si queremos emplear múltiples transiciones con el atajo transition, sólo hay que especificar todos los valores de cada transición y separarlas por comas.
1 |
transition: background-color 0.2s ease-out, transform 0.2s ease-out; |
Resultado con varias transiciones
Si quisiéramos indicar que la transición se aplique a todas las propiedades (color, tamaño…) podemos emplear all
1 2 3 4 |
-webkit-transition: all 0.2s ease-out; -moz-transition: all 0.2s ease-out; -o-transition: all 0.2s ease-out; transition: all 0.2s ease-out; |
De esta forma si el elemento cambia de tamaño, de color, opacidad, etc siempre se realizarán al mismo ritmo, duración y retraso.
Y hasta aquí cómo manejar varias transiciones en CSS, espero que os haya gustado. A seguir picando 🙂