Damián De Luca - Capacitación & Desarrollo Web

Cómo escalar elementos con CSS

Cambiar las dimensiones de elementos desde CSS es una opción que está presente en el estándar desde sus comienzos. Por ejemplo, y a hemos visto que es posible cambiar el tamaño de las cajas utilizando las propiedades de ancho (width) y alto (height).

Si deseamos modificar el tamaño de los elementos de texto podremos utilizar la propiedad font-size.

Como novedad, a partir de CSS3 se incorpora la propiedad transform. Dentro de las transformaciones, encontramos la posibilidad de escalar elementos, mediante scale. Lo interesante de esta característica es que podremos establecer las mismas proporciones para ancho y alto o diferenciarlas.

Ejemplos prácticos de scale

A continuación veremos un ejemplo sobre como duplicar las dimensiones de un elemento cuya id es caja.

#caja
{
 transform: scale(2);
}

Los valores soportados por scale pueden ser números enteros (de cero en adelanta) o con punto decimal.

Si deseamos establecer valores diferenciados para ancho y alto, dentro del paréntesis establecemos los valores dentro del paréntesis separados por coma. Por ejemplo para ampliar el ancho tres veces y el alto cuatro veces, podríamos recurrir a un código como el siguiente:

#caja
{
 transform: scale(3,4);
}

Es importante destacar que la transformación mediante scale no se comporta igual que modificar tamaño por ancho y alto. Esto afecta también la manera en que puede crecer o decrecer el elemento.

Entre otras cosas esto puede producir superposiciones entre elementos o espacios más amplios. Por estas razones nos puede resultar útil trabajar con la propiedad trasnform-origin. Los valores soportados por esta características son números porcentuales. Primero se pasa el desplazamiento X y luego Y. Veamos un ejemplo:

#caja
{
 transform: scale(3,4);
 transform-origin: 30% 20%;
}

Si estás comenzando a trabajar con HTML5 y CSS3 existen diversos editores. Visual Studio Code es uno de los editores libres más utilizados del mercado en la actualidad.

Salir de la versión móvil