Maison >interface Web >tutoriel CSS >Comment empêcher le scintillement blanc lors du rechargement d'une page en mode sombre ?

Comment empêcher le scintillement blanc lors du rechargement d'une page en mode sombre ?

Barbara Streisand
Barbara Streisandoriginal
2024-11-01 07:05:31806parcourir

How to Prevent White Flickering When Reloading a Dark Mode Page?

Problème de scintillement blanc avec le rechargement en mode sombre

Lors de la mise en œuvre d'une fonctionnalité de mode sombre qui exploite le stockage local pour la persistance, un problème courant rencontré est le scintillement d'un fond blanc lors du rechargement de la page. Cela se produit parce que l'analyseur DOM restitue généralement la page avant que les styles du mode sombre ne soient appliqués.

Solution : bloquer le rendu de la page

Pour résoudre ce problème, nous pouvons bloquer la page rendu à l'aide d'un petit script placé dans le de votre document. Ce script définira l'attribut data-theme sur le puis continuez le rendu de la page.

Placez le script suivant dans l'élément avant toute autre balise :

<code class="html"><script>
  // IMPORTANT: set this in <HEAD> top before any other tag.
  const setTheme = (theme) => {
    theme ??= localStorage.theme || "light";
    document.documentElement.dataset.theme = theme;
    localStorage.theme = theme;
  };
  setTheme();
</script></code>

Ensuite, déplacez tous les autres scripts de manière à ne pas bloquer le rendu juste avant le tag:

<code class="html"><script src="js/index.js"></script>
<!-- other <script> tags here -->
<!-- Closing </body> </html> goes here --></code>

Enfin, dans votre fichier js/index.js, utilisez le code suivant :

<code class="js">const elToggleTheme = document.querySelector('#dark-mode-button input[type="checkbox"]');

elToggleTheme.checked = localStorage.theme === "dark";

elToggleTheme.addEventListener("change", () => {
  const theme = elToggleTheme.checked ? "dark" : "light";
  setTheme(theme);
});</code>

En implémentant cette solution, vous pouvez empêcher le scintillement blanc et assurer un transition transparente entre les modes clair et sombre lors du rechargement de la page.

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