recherche
Maisoninterface Webtutoriel CSSBasculement du mode sombre dans les composants Web HTML

Lors de la conception de mon jardin numérique, je savais que je voulais un joli mode sombre. Une fois que j'ai dessiné mon SVG, j'ai commencé à créer un composant Web doté des mêmes fonctionnalités que mon basculement en mode sombre dans React. Cela inclut tout ce que j'ai appris lors de l'audit d'accessibilité de mon site.

En plus de changer le thème, la bascule doit prendre en compte la sélection du schéma de couleurs préféré de l'utilisateur et conserver les préférences de l'utilisateur lors des rechargements. Pour des raisons d'accessibilité, l'annonce du lecteur d'écran de la bascule doit avoir un sens (par exemple, "activer le mode sombre"). Puisque je souhaite afficher un SVG au lieu d'une case à cocher avec du texte, je vais devoir ajouter un style de focus et de survol ainsi qu'une étiquette qui apparaît au survol.

Basculer le composant Web

Tout d'abord, j'ai besoin d'une classe Toggle qui crée un élément HTML. À l'aide de l'API d'élément personnalisé, je définirai en utilisant cette classe.

À l'aide du constructeur de la classe, j'ai défini le innerHTML de à un avec un et SVG en tant qu'enfants. L'étiquette a un attribut de titre, donnant à notre bascule une étiquette "bascule en mode sombre" visible si un utilisateur la survole ou sur . Étant donné que la case à cocher est un enfant de

Dark Mode Toggle in HTML Web Components

Une fois le HTML en place, j'ajoute une fonctionconnectedCallback à la classe. Cette partie de l'API des éléments personnalisés définit les fonctions à utiliser dans le composant et exécute le code lorsque le composant est inséré dans le DOM.

// /components/toggle.js

class Toggle extends HTMLElement {
  constructor() {
    super();
    this.innerHTML = `
      <label title="dark mode toggle">
        <input type="checkbox" id="theme-toggle" class="theme-switch">
        <svg id="daisy">{SVG code removed for brevity}</svg>
      </label>
    `
    this.setAttribute("class", "toggle-component");
  }

  connectedCallback() {
    function switchTheme(e) {
      if (e.target.checked) {
        setTheme('dark');
        return;
      }

      setTheme('light');   
    };

    function setTheme(themeName) {
      localStorage.setItem('theme', themeName);
      document.documentElement.setAttribute('data-theme', themeName);
    };

    function setCheckBox(toggleSwitch, theme) {
      toggleSwitch.checked = theme === 'dark' ? true : false;
    }

    function keepTheme() {
      const toggleSwitch = document.querySelector('#theme-toggle');
      toggleSwitch.addEventListener('change', switchTheme, false);
      const theme = localStorage.getItem('theme');
      if (theme) {
        setTheme(theme);
        setCheckBox(toggleSwitch, theme);
        return;
      };

      const prefersLightTheme = window.matchMedia('(prefers-color-scheme: light)');
      if (prefersLightTheme.matches) {
        setTheme('light');
        return;
      };

      setTheme('dark');
      setCheckBox(toggleSwitch, 'dark');
    };

    document.addEventListener("DOMContentLoaded", keepTheme);    
  }
}

customElements.define("toggle-component", Toggle);

Parce que est inséré dans le DOM avant le chargement de la page, le seul code qui s'exécute immédiatement ajoute un écouteur d'événement. L'écouteur d'événements appelle keepTheme dès que la page est chargée. Tout d'abord, keepTheme ajoute un écouteur d'événement au qui appelle switchTheme lorsqu'un utilisateur interagit avec lui. switchTheme transmet « dark » à setTheme si la case est cochée et « light » si elle ne l'est pas. La chaîne transmise à setTheme est définie comme thème CSS et enregistrée dans localStorage qui persistera lors des rechargements.

Le reste de keepTheme est dédié au choix du bon thème au chargement. Tout d’abord, il vérifie localStorage pour voir si les préférences de l’utilisateur sont déjà définies. Ensuite, il vérifie si le schéma de couleurs préférées est défini sur « clair ». Enfin, il est par défaut en mode sombre. Pour les modes sombre et clair, j'appelle setTheme. Pour le mode sombre, j'appelle également setCheckbox. La case à cocher se monte dans un état non coché. Un lecteur d'écran annoncera "mode sombre" et indiquera si la case est cochée. Pour obtenir une annonce du type « basculement du mode sombre coché » ou « basculement du mode sombre activé », je dois cocher la case par programme lorsque je définis le thème sur « sombre » au chargement.

Dark Mode Toggle in HTML Web Components

Dark Mode Toggle in HTML Web Components

Basculer le style

J'ai choisi de dessiner un design assez simple pour pouvoir mettre mon code SVG directement dans le composant Web et changer la couleur de remplissage par programme. De cette façon, la couleur d’arrière-plan de la marguerite correspond toujours au thème. Ensuite, j'utilise l'opacité : 0 ; pour masquer la case à cocher et la positionner au milieu de l'image. Enfin, j'ajoute les styles de survol et de mise au point.

Dark Mode Toggle in HTML Web Components

// /components/toggle.js

class Toggle extends HTMLElement {
  constructor() {
    super();
    this.innerHTML = `
      <label title="dark mode toggle">
        <input type="checkbox" id="theme-toggle" class="theme-switch">
        <svg id="daisy">{SVG code removed for brevity}</svg>
      </label>
    `
    this.setAttribute("class", "toggle-component");
  }

  connectedCallback() {
    function switchTheme(e) {
      if (e.target.checked) {
        setTheme('dark');
        return;
      }

      setTheme('light');   
    };

    function setTheme(themeName) {
      localStorage.setItem('theme', themeName);
      document.documentElement.setAttribute('data-theme', themeName);
    };

    function setCheckBox(toggleSwitch, theme) {
      toggleSwitch.checked = theme === 'dark' ? true : false;
    }

    function keepTheme() {
      const toggleSwitch = document.querySelector('#theme-toggle');
      toggleSwitch.addEventListener('change', switchTheme, false);
      const theme = localStorage.getItem('theme');
      if (theme) {
        setTheme(theme);
        setCheckBox(toggleSwitch, theme);
        return;
      };

      const prefersLightTheme = window.matchMedia('(prefers-color-scheme: light)');
      if (prefersLightTheme.matches) {
        setTheme('light');
        return;
      };

      setTheme('dark');
      setCheckBox(toggleSwitch, 'dark');
    };

    document.addEventListener("DOMContentLoaded", keepTheme);    
  }
}

customElements.define("toggle-component", Toggle);

Utilisation du composant Web bascule

Tout ce que j'ai à faire est d'importer ma feuille de style et mon script de composant dans le fichier

d'une page HTML. Ensuite, je peux appeler n'importe où dans la page.
/* /styles/styles.css */

[data-theme="light"] {
  --toggle-background: #242D54;
}

[data-theme="dark"] {
  --toggle-background: #282e53;
}

#daisy path {
  fill: var(--toggle-background);
}

.theme-switch {
  position: relative;
  bottom: 30px;
  left: 55px;
  width: 1em;
  height: 1em;
  opacity: 0;
}

.theme-switch:focus + #daisy path,
.theme-switch:hover + #daisy path {
  fill: white;
}

.theme-switch:focus + #daisy {
  outline: 3px solid white;
  outline-offset: 5px;
}

Dark Mode Toggle in HTML Web Components

Dark Mode Toggle in HTML Web Components

Conclusion

Je me suis amusé à faire en sorte que mon mode sombre fonctionne aussi bien dans un composant Web que dans React. Vous pouvez le voir en direct dans mon jardin numérique et le code complet dans le dépôt GitHub.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Draggin & # 039; et droppin & # 039; en réactionDraggin & # 039; et droppin & # 039; en réactionApr 17, 2025 am 11:52 AM

L'écosystème React nous offre de nombreuses bibliothèques qui se concentrent sur l'interaction de la glisser et de la chute. Nous avons react-dnd, react-beeufuly-dnd,

Logiciel rapideLogiciel rapideApr 17, 2025 am 11:49 AM

Il y a eu des choses merveilleusement interconnectées à propos des logiciels rapides ces derniers temps.

Gradients imbriqués avec un clip de fondGradients imbriqués avec un clip de fondApr 17, 2025 am 11:47 AM

Je ne peux pas dire que j'utilise souvent le clip de fond. Je ne parierai presque presque jamais dans le travail CSS au jour le jour. Mais je me suis souvenu de cela dans un post de Stefan Judis,

Utilisation de la réalisation de demandes avec des crochets ReactUtilisation de la réalisation de demandes avec des crochets ReactApr 17, 2025 am 11:46 AM

L'animation avec des demandes de châssis devrait être facile, mais si vous n'avez pas lu de manière approfondie de la documentation de React, vous rencontrerez probablement quelques choses

Besoin de faire défiler en haut de la page?Besoin de faire défiler en haut de la page?Apr 17, 2025 am 11:45 AM

Peut-être le moyen le plus simple d'offrir cela à l'utilisateur est un lien qui cible un ID sur l'élément. Tellement comme ...

La meilleure API (GraphQL) est celle que vous écrivezLa meilleure API (GraphQL) est celle que vous écrivezApr 17, 2025 am 11:36 AM

Écoutez, je ne suis pas un expert GraphQL mais j'aime travailler avec. La façon dont elle expose les données en tant que développeur frontal est assez cool. C'est comme un menu de

Actualités de plate-forme hebdomadaire: bookmarklet d'espacement de texte, attente de haut niveau, nouvel indicateur de chargement d'ampliActualités de plate-forme hebdomadaire: bookmarklet d'espacement de texte, attente de haut niveau, nouvel indicateur de chargement d'ampliApr 17, 2025 am 11:26 AM

Au cours de cette semaine, un Bookmarklet pratique pour inspecter la typographie, en utilisant Await pour bricoler comment les modules JavaScript s'importent, ainsi que Facebook & # 039; S

Diverses méthodes pour étendre une boîte tout en préservant le rayon de la frontièreDiverses méthodes pour étendre une boîte tout en préservant le rayon de la frontièreApr 17, 2025 am 11:19 AM

J'ai récemment remarqué un changement intéressant sur Codepen: sur le plan des stylos sur la page d'accueil, il y a un rectangle avec des coins arrondis se développant dans le dos.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

Télécharger la version Mac de l'éditeur Atom

Télécharger la version Mac de l'éditeur Atom

L'éditeur open source le plus populaire

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

DVWA

DVWA

Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel