Heim > Web-Frontend > CSS-Tutorial > Wie verhindert man weißes Flackern beim Neuladen einer Dark-Mode-Seite?

Wie verhindert man weißes Flackern beim Neuladen einer Dark-Mode-Seite?

Barbara Streisand
Freigeben: 2024-11-01 07:05:31
Original
804 Leute haben es durchsucht

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

Problem mit weißem Flackern beim Neuladen im Dunkelmodus

Bei der Implementierung einer Dunkelmodusfunktion, die den lokalen Speicher für die Persistenz nutzt, ist ein häufiges Problem das Flackern eines weißen Hintergrunds beim Neuladen der Seite. Dies liegt daran, dass der DOM-Parser die Seite normalerweise rendert, bevor die Dark-Mode-Stile angewendet werden.

Lösung: Seitenrendering blockieren

Um dieses Problem zu beheben, können wir die Seite blockieren Rendering mithilfe eines kleinen Skripts, das im Ihres Dokuments. Dieses Skript legt das data-theme-Attribut auf der Seite fest. Element und fahren Sie dann mit dem Rendern der Seite fort.

Fügen Sie das folgende Skript in das -Element ein. vor jedem anderen Tag:

<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>
Nach dem Login kopieren

Als nächstes verschieben Sie alle anderen Skripte in eine nicht-Rendering-blockierende Weise direkt vor dem schließenden tag:

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

Verwenden Sie abschließend in Ihrer js/index.js-Datei den folgenden Code:

<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>
Nach dem Login kopieren

Durch die Implementierung dieser Lösung können Sie das weiße Flimmern verhindern und sicherstellen, dass a Nahtloser Übergang zwischen hellem und dunklem Modus beim Neuladen der Seite.

Das obige ist der detaillierte Inhalt vonWie verhindert man weißes Flackern beim Neuladen einer Dark-Mode-Seite?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage