Maison >interface Web >tutoriel CSS >Comment empêcher le scintillement blanc lors du rechargement d'une page en mode sombre ?
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!