Gradientes lineales

La función linear-gradient() de CSS


El primer tipo de gradiente es el gradiente lineal, que permite crear fondos degradados que van en una dirección y cambian de un color a otro, dependiendo de la lista de colores indicada por parámetro.

La función linear-gradient()

La sintaxis a utilizar debe ser una de las siguientes:

Función y modalidadTipo de gradiente
linear-gradient( , , ... )Gradiente de colores (hacia abajo).
linear-gradient( , , , ... )Gradiente con dirección específica.
linear-gradient( , , , ... )Se indica donde comienza a cambiar el color.
linear-gradient( , , , ... )Se indica inicio y fin de cada color.

El ejemplo más básico de los anteriores es la primera modalidad, donde simplemente indicaremos los colores del gradiente uno detrás de otro, y como mínimo, deben haber dos colores:

.element {
  width: 600px;
  height: 100px;
  background-image: linear-gradient(blue, red);
}
<div class="element"></div>

Esto creará un degradado con los colores indicados (de azul a rojo) y por defecto, la dirección del gradiente será desde arriba hacia abajo. Si se desea, se puede añadir más colores para hacer un gradiente más complejo:

Gradiente lineal

Pero hay otros parámetros que se pueden indicar para hacer gradientes más flexibles y personalizables a parte de la lista de colores. Son los siguientes parámetros:

ParámetrosValor
Dirección que tendrá el gradiente lineal. El valor por defecto es to bottom.
La dirección también se puede indicar con un número de grados. Alternativa a la opción anterior.
Uno de los colores del gradiente
Opcional: Se puede indicar a que altura se encuentra el centro del color que lo precede.
Opcional: Se puede indicar a que altura comienza y acaba el color que lo precede.

* Los valores también pueden indicarse con porcentajes .

Dirección del gradiente

En el ejemplo visual de la imagen anterior, la dirección del gradiente es horizontal (hacia la derecha). El primer ejemplo tiene sólo 2 colores (azul y rojo), mientras que el segundo tiene 3 colores (azul, amarillo y rojo). Ambos tienen como dirección una orientación hacia la derecha. Esto en código se traduciría en lo siguiente:

.element {
  width: 600px;
  height: 100px;

  /* Primer ejemplo */
  background-image: linear-gradient(to right, blue, red);

  /* Segundo ejemplo, sobreescribe al anterior */
  background-image: linear-gradient(to right, blue, yellow, red);
}
<div class="element"></div>

Como vemos, el primer parámetro utilizado fue to right, que es lo que indica la orientación del gradiente. En este parámetro se puede indicar tanto una palabra clave como un número de grados que represente la dirección:

Orientación de dirección

Para que quede aún más claro, veamos una tabla de equivalencias con las diferentes unidades que podríamos usar:

DirecciónGradosGradianesRadianesGiro
to top0 ó 360deg0 ó 400grad0 ó rad0 ó 1turn
to top right45deg50grad0.78rad (π/4)0.125turn
to right90deg100grad1.57rad (π/2)0.250turn
to bottom right145deg150grad2.35rad0.375turn
to bottom180deg200grad3.14rad (π)0.5turn
to bottom left215deg250grad3.92rad0.625turn
to left270deg300grad4.71rad (2π)0.75turn
to top left325deg350grad5.49rad0.875turn

Nota: Si utilizas alguna de las unidades en lugar de las palabras clave puedes usar valores intermedios (por ejemplo, 280deg o 58deg) y ser más preciso con la dirección si lo necesitas.

Posición del color

Por defecto, las distancias entre colores se ajustan automáticamente con proporciones equilibradas. Sin embargo, si especificamos un tamaño (porcentaje o píxeles, por ejemplo) justo después del color en cuestión, podremos variar la posición en la que aparece ese color.

.element {
  width: 500px;
  height: 100px;

  /* Básico, con colores con distancias equilibradas */
  background: linear-gradient(to right, black, blue, gold, green, red);

  /* Equivalente al anterior */
  background:
    linear-gradient(
      to right,
      black 0%,     /* Color 100% negro en el punto 0% y comienza a cambiar */
      blue 25%,     /* Color 100% azul en el punto 25% y comienza a cambiar */
      gold 50%,     /* Color 100% dorado en el punto 50% y comienza a cambiar */
      green 75%,    /* Color 100% verde en el punto 75% y comienza a cambiar */
      red 100%      /* Color 100% rojo en el punto 100% */
    );
}
<div class="element"></div>

Este porcentaje o representa el punto central del color que lo precede, respecto al tamaño del gradiente completo. Observa la imagen que tenemos a continuación, donde se muestran tres colores: el azul comenzando a cambiar en la posición 50% del elemento, el rojo comenzando a cambiar en la posición 55%, y el verde comenzando a cambiar en la posición 75%. Se vería algo así:

Gradiente CSS con tamaño

Sin embargo, nos queda una modalidad más que podemos utilizar.

Inicio y final del color

En esta última modalidad podemos establecer dos tamaños después de indicar el color, uno correspondiente al momento donde empieza el color y otro correspondiente al momento donde acaba el color. Ten en cuenta que esto no quiere decir que después de ese punto, no exista un cambio paulatino a otro color donde se van mezclando:

.element {
  width: 500px;
  height: 100px;

  /* Delimitando los colores con corte brusco */
  background:
    linear-gradient(
      to right,
      black 0% 25%,   /* Color negro desde 0% hasta 25%, sin degradación */
      blue 25% 50%,   /* Color azul desde 25% hasta 50%, sin degradación */
      gold 50% 75%,   /* Color dorado desde 50% hasta 75%, sin degradación */
      green 75% 100%  /* Color verde desde 75% hasta 100%, sin degradación */
    );

  /* Equivalente al anterior */
  background:
    linear-gradient(
      to right,
      black 25%,      /* Si se omite, el punto de partida, al ser el primer color es 0% */
      blue 25% 50%,
      gold 50% 75%,
      green 75%       /* Si se omite, el punto de final, al ser el último color es 100% */
    );
}
<div class="element"></div>

En este caso, los saltos de un color a otro son totalmente bruscos, ya que el porcentaje de terminación de un color, coincide con el porcentaje de inicio del siguiente color. También podríamos evitar que coincidan, estableciendo un pequeño degradado entre porcentajes.

La función repeating-linear-gradient()

Si en lugar de utilizar la función linear-gradient() usamos la función repeating-linear-gradient(), podemos indicar un patrón de colores que se van a repetir continuamente.

El truco está en que los tamaños indicados a continuación del color, teniendo en cuenta que no debe llegar al 100%, y el navegador se encargará de completarlos y repetirlos una y otra vez hasta que no quede más espacio en el elemento HTML seleccionado:

.element {
  width: 500px;
  height: 100px;

  background:
    linear-gradient(
      to right,
      blue 0 10%,
      yellow 10% 20%,
      red 20% 30%,
      blue 30% 40%,
      yellow 40% 50%,
      red 50% 60%,
      blue 60% 70%,
      yellow 70% 80%,
      red 80% 90%,
      blue 90% 100%,
    );

  /* La propiedad anterior, se puede resumir: */
  background:
    repeating-linear-gradient(
      blue 0 10%,
      yellow 10% 20%,
      red 20% 30%
    );
}
<div class="element"></div>

Como se puede ver, el patrón azul-amarillo-rojo se ajusta a los tamaños indicados y el navegador se encarga de repetirlos una y otra vez.

¿Quién soy yo?

Soy Manz, vivo en Tenerife (España) y soy streamer partner en Twitch y profesor. Me apasiona el universo de la programación web, el diseño y desarrollo web y la tecnología en general. Aunque soy full-stack, mi pasión es el front-end, la terminal y crear cosas divertidas y locas.

Puedes encontrar más sobre mi en Manz.dev