Temas

Incluso el desarrollo de la marca puede ser responsivo. Puedes ajustar la presentación de tu sitio web para que coincida con las preferencias del usuario. Pero primero, aquí te explicamos cómo extender el desarrollo de la marca de tu sitio web para incluir al navegador en sí.

Algunos navegadores te permiten sugerir un color de tema en función de la paleta de tu sitio web. La interfaz del navegador se adapta al color sugerido. Agrega el color en un elemento meta llamado theme-color en el head de tus páginas.

<meta name="theme-color" content="#00D494">
Clearleft punto com. Diseño web resiliente punto com. El grupo Session.org.
Se ven tres sitios web en el navegador Safari. Cada uno tiene su propio color de tema que se extiende a la interfaz del navegador.

Puedes actualizar el valor de theme-color con JavaScript. Pero usa este poder con prudencia. Puede resultar abrumador para los usuarios si el esquema de colores de su navegador cambia con demasiada frecuencia. Piensa en maneras sutiles de ajustar el color del tema. Si los cambios son demasiado molestos, los usuarios se distraerán.

También puedes especificar un color de tema en un archivo de manifiesto de aplicación web. Este es un archivo JSON con metadatos sobre tu sitio web.

Vínculo al archivo de manifiesto de head de tus documentos. Usa un elemento link con un valor rel de manifest.

<link rel="manifest" href="/manifest.json">

En el archivo de manifiesto, genera una lista de tus metadatos con pares clave-valor.

{
 
"short_name": "Clearleft",
 
"name": "Clearleft design agency",
 
"start_url": "/",
 
"background_color": "#00D494",
 
"theme_color": "#00D494",
 
"display": "standalone"
}

Si un visitante decide agregar tu sitio web a su pantalla de inicio, el navegador utilizará la información del archivo de manifiesto para mostrar un acceso directo adecuado.

Cómo proporcionar un modo oscuro

Muchos sistemas operativos permiten que los usuarios especifiquen una preferencia por una paleta de colores claro u oscuro, lo que es una buena idea optimizar el sitio según las preferencias de temas de los usuarios. Puedes acceder a esta preferencia en una función multimedia llamada prefers-color-scheme.

@media (prefers-color-scheme: dark) {
 
// Styles for a dark theme.
}

Especifica colores de tema con la función multimedia prefers-color-scheme dentro del elemento meta.

<meta name="theme-color" content="#ffffff" media="(prefers-color-scheme: light)">
<meta name="theme-color" content="#000000" media="(prefers-color-scheme: dark)">

También puedes usar la función multimedia prefers-color-scheme dentro de SVG. Si usas un archivo SVG para el ícono de página, puedes ajustarlo para el modo oscuro. Thomas Steiner escribió acerca de prefers-color-scheme en íconos de página SVG para íconos de modo oscuro.

Temas con propiedades personalizadas

Si usas los mismos valores de color en varios lugares del CSS, podría resultar bastante tedioso repetir todos los selectores en una consulta de medios prefers-color-scheme.

body {
 
background-color: white;
 
color: black;
}
input
{
 
background-color: white;
 
color: black;
 
border-color: black;
}
button
{
 
background-color: black;
 
color: white;
}
@media (prefers-color-scheme: dark) {
  body
{
   
background-color: black;
   
color: white;
 
}
  input
{
   
background-color: black;
   
color: white;
   
border-color: white;
 
}
  button
{
   
background-color: white;
   
color: black;
 
}
}

Usa propiedades personalizadas de CSS para almacenar los valores de color. Las propiedades personalizadas funcionan como variables en un lenguaje de programación. Puedes actualizar el valor de una variable sin actualizar su nombre.

Si actualizas los valores de tus propiedades personalizadas en una búsqueda de medios prefers-color-scheme, ocurrirá lo siguiente: no tendrás que escribir todos los selectores dos veces.

html {
 
--page-color: white;
 
--ink-color: black;
}
@media (prefers-color-scheme: dark) {
  html
{
   
--page-color: black;
   
--ink-color: white;
 
}
}
body
{
 
background-color: var(--page-color);
 
color: var(--ink-color);
}
input
{
 
background-color: var(--page-color);
 
color: var(--ink-color);
 
border-color: var(--ink-color);
}
button
{
 
background-color: var(--ink-color);
 
color: var(--page-color);
}

Consulta cómo crear un esquema de colores para ver ejemplos más avanzados de temas con propiedades personalizadas.

Imágenes

Si usas SVG en tu HTML, también puedes aplicar propiedades personalizadas allí.

svg {
 
stroke: var(--ink-color);
 
fill: var(--page-color);
}

Ahora tus iconos cambiarán de color junto con los demás elementos de tu página.

Si deseas reducir el brillo de las imágenes fotográficas cuando se muestran en modo oscuro, puedes aplicar un filtro en CSS.

@media (prefers-color-scheme: dark) {
  img
{
   
filter: brightness(.8) contrast(1.2);
 
}
}
Tres fotos con brillo normal. Tres fotos con un poco menos de brillo.
El efecto es sutil, pero puedes disminuir el brillo de las imágenes en el modo oscuro.

En el caso de algunas imágenes, te recomendamos que las cambies por completo en modo oscuro. Por ejemplo, es posible que desees mostrar un mapa con un esquema de colores más oscuro. Usa el elemento <picture> que contiene un elemento <source> con la consulta de medios prefers-color-scheme.

<picture>
 
<source srcset="darkimage.png" media="(prefers-color-scheme: dark)">
 
<img src="lightimage.png" alt="A description of the image.">
</picture>
Dos mapas de Broolyn, uno con colores claros y otro con colores oscuros.
Dos versiones del mismo mapa: una para el modo claro y otra para el modo oscuro.

Formularios

Los navegadores ofrecen una paleta de colores predeterminada para los campos de los formularios. Informa al navegador que tu sitio ofrece un modo oscuro y claro. De esta manera, el navegador puede proporcionar el estilo predeterminado adecuado para los formularios.

Agrega lo siguiente al CSS:

html {
 
color-scheme: light;
}
@media (prefers-color-scheme: dark) {
  html
{
   
color-scheme: dark;
 
}
}

También puedes usar HTML. Agrega lo siguiente a head de tus documentos:

<meta name="supported-color-schemes" content="light dark">

Usa la propiedad accent-color en CSS para definir el estilo de las casillas de verificación, los botones de selección y algunos otros campos de formulario.

html {
 
accent-color: red;
}

Es común que los temas oscuros tengan colores de marca tenues. Puedes actualizar el valor de accent-color para el modo oscuro.

html {
 
accent-color: red;
}
@media (prefers-color-scheme: dark) {
  html
{
   
accent-color: pink;
 
}
}

Para ello, tiene sentido usar una propiedad personalizada, de modo que puedas mantener todas las declaraciones de colores en un solo lugar.

html {
 
color-scheme: light;
 
--page-color: white;
 
--ink-color: black;
 
--highlight-color: red;
}
@media (prefers-color-scheme: dark) {
  html
{
   
color-scheme: dark;
   
--page-color: black;
   
--ink-color: white;
   
--highlight-color: pink;
 
}
}
html
{
 
accent-color: var(--highlight-color);
}
body
{
 
background-color: var(--page-color);
 
color: var(--ink-color);
}

Proporcionar un modo oscuro es solo un ejemplo de cómo adaptar tu sitio para que se ajuste a las preferencias de tus usuarios. A continuación, aprenderás cómo adaptar tu sitio a todo tipo de consideraciones de accesibilidad.

Verifica tus conocimientos

Pon a prueba tus conocimientos sobre temas

Para proporcionar colores de tema que afecten el navegador fuera de la página web, usa:

JavaScript
Un "color-tema" Etiqueta <meta>
CSS
Un manifiesto de app web

Para conectarte a la preferencia del sistema del usuario con respecto a un tema oscuro o claro, usa lo siguiente:

La búsqueda de medios (prefers-color-scheme)
JavaScript

Se admite el tema oscuro, pero todas las entradas del formulario siguen teniendo un tema claro. ¿Qué puedes hacer?

Agrega <meta name="supported-color-schemes" content="light dark"> a tu etiqueta HTML <head>.
Escribe varios elementos de CSS para cambiar todos los valores predeterminados de la entrada.
Agrega html { color-scheme: light dark; } a tu CSS.