POLITICA DE COOKIES

Q2BSTUDIO.COM utiliza cookies técnicas, analíticas, de sesión y de publicidad con la finalidad de prestar un mejor servicio. No obstante, necesitamos su consentimiento explícito para poder utilizarlas. Así mismo puede cambiar la configuración de las cookies u obtener más información aquí .

Configurar tema oscuro en Angular Material

Configurar tema oscuro en Angular Material paso a paso

Publicado el 18/08/2025

Hace tiempo que el tema oscuro se ha convertido en un estándar para muchas aplicaciones aunque no siempre es imprescindible. En este artículo explicaré cómo aplicar un tema oscuro con Angular Material y cómo permitir que el usuario lo cambie. También incluyo ejemplos de SCSS y TypeScript para facilitar la implementación.

Primero configure el tema general de Material. Un ejemplo de SCSS para el tema base sería:

html { @include mat.theme(( color: mat.$azure-palette, typography: Roboto, )); }

Con esto estará usando el tema claro por defecto. Para soportar modo oscuro aprovechamos la propiedad CSS color-scheme y la capacidad interna de Angular Material para alternar light y dark:

html { color-scheme: light dark; @include mat.theme(( color: mat.$azure-palette, typography: Roboto, )); }

Al establecer color-scheme: light dark el modo por defecto se adapta a la preferencia del sistema del usuario. Además puede sobrescribir propiedades específicas cuando el modo oscuro está activo, por ejemplo el fondo:

html { color-scheme: light dark; @include mat.theme(( color: mat.$azure-palette, typography: Roboto, )); @media (prefers-color-scheme: dark) { @include mat.theme(( color: mat.$azure-palette ), $overrides: ( background: darkblue ) ); } }

Si desea que el usuario cambie el tema manualmente cree un control toggle o select con las opciones system, light y dark. Un ejemplo sencillo en TypeScript con signal y Renderer2 para aplicar el estilo al body:

public readonly theme = signal(system); private readonly _renderer = inject(Renderer2); constructor() { effect(() => this._setTheme(this.theme())); } private _setTheme(theme: ThemeMode) { this._renderer.setProperty(document.body.style, color-scheme, theme === system ? light dark : theme); }

La idea es almacenar la preferencia del usuario en local storage o en su perfil y restaurarla en cada carga. También puede ofrecer un modo system que respete la preferencia del sistema y un modo manual para forzar claro u oscuro.

Como bonus puede mejorar la transición visual entre temas usando la experimental API startViewTransition cuando el navegador la soporte. Un ejemplo de uso en un componente:

constructor(@Inject(DOCUMENT) private readonly _document: Document) { effect(() => { const theme = this.theme(); if (!this._document.startViewTransition) { this._setTheme(theme); return; } this._document.startViewTransition(() => { this._setTheme(theme); }); }); }

Y un ejemplo de animación CSS para la nueva vista:

::view-transition-old(root) { animation-delay: 500ms; } ::view-transition-new(root) { animation: circle-in 500ms; } @keyframes circle-in { from { clip-path: circle(0% at 50% 0%); } to { clip-path: circle(120% at 50% 0%); } }

Con estos cambios tendrá un control completo sobre el tema oscuro en Angular Material y podrá ofrecer una experiencia pulida tanto para usuarios que siguen la preferencia del sistema como para los que eligen manualmente.

Sobre nosotros: en Q2BSTUDIO somos una empresa de desarrollo de software y aplicaciones a medida especializada en soluciones tecnológicas avanzadas. Ofrecemos servicios de software a medida, aplicaciones a medida, inteligencia artificial, ia para empresas, agentes IA y desarrollo de experiencias con Power BI. También ayudamos a las organizaciones con ciberseguridad, servicios cloud aws y azure y servicios inteligencia de negocio para tomar decisiones basadas en datos.

Si necesita integrar un tema oscuro como parte de una aplicación a medida o quiere que su producto incluya capacidades de inteligencia artificial o ciberseguridad contacte con Q2BSTUDIO. Podemos diseñar software a medida, integrar agentes IA, implementar soluciones de inteligencia artificial y servicios cloud aws y azure, y crear paneles con power bi para exponer indicadores clave.

Palabras clave para mejorar el posicionamiento: aplicaciones a medida, software a medida, inteligencia artificial, ciberseguridad, servicios cloud aws y azure, servicios inteligencia de negocio, ia para empresas, agentes IA, power bi.

Si quiere que implementemos esta funcionalidad en su proyecto o desea una consultoría sobre seguridad, cloud o inteligencia artificial, en Q2BSTUDIO estamos preparados para ayudarle con soluciones personalizadas y escalables.

Fin del artículo, inicio de la diversión
Construyendo software juntos

Dando vida a tus ideas desde 2008

Diseñamos aplicaciones móviles y de escritorio innovadoras que cumplen con tus requisitos específicos y mejoran la eficiencia operativa.
Más info
Cuéntanos tu visión
Sea cual sea el alcance, podemos convertir tu idea en realidad. Envíanosla y charlemos sobre tu proyecto o una colaboración futura.
Contáctanos
artículos destacados
Live Chat
Enviado correctamente.

Gracias por confiar en Q2BStudio