Colores nombrados
Formatos de color más comunes
En CSS existen diferentes formas de especificar un color. Las más comunes son:
- Colores nombrados
- Hexadecimal
- RGB
- RGBA
- HSL
- HSLA
Colores nombrados
Los colores nombrados son valores predefinidos que utilizan nombres de colores en inglés, como red, blue, green, etc.
Usualmente esta es la primera forma en la que aprendemos a utilizar valores de tipo <color> ya que se encuentran en la lista de autocompletado de VS Code. Podemos encontrar la lista completa aquí: Colores nombrados.
Hexadecimal
Es un formato que utiliza valores del sistema hexadecimal para especificar colores.
El sistema hexadecimal utiliza 16 símbolos para contar: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, a, b, c, d, e, f. Donde el valor mínimo es 0 y el máximo es f.
Los colores que usan 6 valores o tres pares de valores son los más comunes:
#RRGGBB- El primer par de valores indica la cantidad de rojo (Red)
- El segundo par de valores indica la cantidad de verde (Green)
- El tercer par de valores indica la cantidad de azul (Blue)
Por ejemplo:
#ff0000Sería un color completamente rojo:
También podemos encontrarlo en formato de 8 valores o 4 pares, donde el último par indica la opacidad del color:
#RRGGBBAADonde A es el valor Alpha o la opacidad.
Por ejemplo:
#ff000080Sería un color completamente rojo con una opacidad hexadecimal de 80 que es equivalente a 50%.
Y también podemos encontrarlo en formato de 3 valores:
#RGBQue en realidad se vuelve un equivalente a repetir el valor en cada color.
Por ejemplo:
#0f0Es equivalente a:
#00ff00Y:
#abcEs equivalente a:
#aabbccEstos valores no son sensibles a mayúsculas y minúsculas por lo que se usar
tanto f00 como F00
RGB y RGBA
RGB y RGBA son formatos que utilizan una función para especificar colores.
En este artículo veremos la versión moderna de rgb() que nos permite poner diferentes tipos de valores para cada color y opacidad.
Con números
La sintaxis es la siguiente:
rgb(R G B)Donde:
Res el valor de rojo (red)Ges el valor de verde (green)Bes el valor de azul (blue)
Y podemos usar valores del 0 al 255 para cada color.
La versión más reciente de esta función debe hacer separaciones entre los valores usando espacios en lugar de comas
Por ejemplo:
rgb(0 0 255)Adicionalmente, podemos usar valores de 0 a 1 para la opacidad añadiendo una diagonal seguida del valor:
rgb(R G B / A)Por ejemplo:
rgba(0 0 255 / 0.5)Con porcentajes
También podemos usar porcentajes para especificar los valores.
rgb(30% 20% 50%)Incluyendo la opacidad:
rgb(30% 20% 50% / 50%)Incluso podemos combinar la notación de porcentajes con la de números:
rgb(0 30% 255 / 80%)Sobre las funciones de legado
Anteriormente las funciones RGB estaban divididas entre rgb() y rgba(), los valores tenían que estar separados por comas y no se podían combinar números con porcentajes.
En la versión actual de rgb() debemos usar espacios para separar los valores y podemos agregar la opacidad dentro de la misma función sin problema así como combinar números con porcentajes.
HSL y HSLA
HSL y HSLA también son formatos que utilizan una función para especificar colores.
Y de igual manera tienen una versión moderna que nos permite agregar opacidad de manera opcional.
La sintaxis es la siguiente:
hsl(H S L / A)Donde:
Hes el valor del tono (Hue)Ses el valor de la saturación (Saturation)Les el valor de la luminosidad (Lightness)/ Aes la opacidad (Alpha). Es un valor opcional.
H acepta valores de tipo <number> o <angle>. Es decir, números del 0 al 360, o valores en grados, vueltas, etc.
S acepta valores de tipo <percentage>. Es decir, porcentajes del 0% al 100%. Si olvidamos el % se seguirá interpretando como porcentaje.
L también acepta valores de tipo <percentage>.
A acepta valores de tipo <alpha-value>, que en realidad sólo son valores del 0 al 1 o del 0% al 100%.
Por ejemplo:
hsl(0 100% 50%)Comentarios
Roadmap
Web Dev (Frontend)
Artículo 19 de 63