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í.

Personaliza la interfaz del navegador

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:

CSS
Es probable que la información del tema CSS cause un destello de color normal, lo que representa una experiencia del usuario no deseada.
JavaScript
Solo si lo usas para actualizar un atributo "theme-color" <meta>.
Un manifiesto de app web
Se puede proporcionar manifest.json, que incluye campos para especificar colores de temas y ajustar el tono de la app que se abre desde la pantalla principal de un dispositivo móvil.
Un "color-tema" Etiqueta <meta>
Tan pronto como sea posible, un navegador puede detectar este color de tema en la etiqueta <head>, lo que evita destellos de color no deseados.

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)
Pasa el valor que quieres verificar, como oscuro o claro, y listo.
JavaScript
Luego, usa la sintaxis de consulta de medios de CSS para solicitar el estado actual de la preferencia.

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

Agrega html { color-scheme: light dark; } a tu CSS.
Esto le indica al CSS que las entradas del formulario deben coincidir con el esquema de colores del sistema.
Agrega <meta name="supported-color-schemes" content="light dark"> a tu etiqueta HTML <head>.
Esto indica desde HTML que las entradas del formulario deben coincidir con el esquema de colores del sistema.
Escribe varios elementos de CSS para cambiar todos los valores predeterminados de la entrada.
Esto también funciona, pero es un poco más difícil.