suchen
HeimWeb-FrontendCSS-TutorialEin dunkler Modus wechselt mit React und ThemeProvider

Dieser Artikel zeigt, wie ein Dark-Modus-Umschalter für eine React-Anwendung mit stilvollen Komponenten erstellt wird. Es umfasst das Einrichten des Projekts, das Erstellen von hellen und dunklen Themen, die Implementierung der Umschaltfunktionen, das Erstellen einer wiederverwendbaren Umschaltkomponente und das Nutzung des bevorzugten Farbschemas des Benutzers. Lassen Sie uns den Text für Klarheit und Zuversicht verfeinern.

Ein dunkler Modus wechselt mit React und ThemeProvider

Viele Websites bieten jetzt einen dunklen Modus, verbessern die Lesbarkeit und reduzieren die Augenbelastung. Dieses Tutorial führt Sie durch das Erstellen eines Dark-Modus-Umschusses für Ihre React-App mit gestylerischen Komponenten und einem benutzerdefinierten Haken.

Einrichten des Projekts

Erstellen Sie mithilfe eines neuen React-Projekts mit create-react-app :

 NPX erstellen React-App My-App
CD my-App
Garn beginnen

Styled-Komponenten installieren:

 Garn Fügen Sie gestylerte Komponenten hinzu

Erstellen Sie theme.js für Themenvariablen:

 // thema.js
exportieren const lighttheme = {
  Körper: '#e2e2e2',
  Text: '#363537',
  ToggleBorder: '#fff',
  Gradient: 'Linear-Gradient ( #39598a, #79d7ed)',
};

exportieren const dunndheme = {
  Körper: '#363537',
  Text: '#fafafa',
  ToggleBorder: '#6b8096',
  Gradient: 'Linear-Gradient ( #091236, #1E215d)',,
};

Und global.js für das Basisstyling:

 // Global.js
Import {CreateGlobalStyle} aus 'Stilkomponenten';

Export const GlobalStyles = CreateGlobalStyle``
  *, *:: After, *:: vor {Boxgrößen: Border-Box; }
  Körper {
    Ausrichtung: Zentrum;
    Hintergrund: $ {({thema}) => thema.body};
    Farbe: $ {({thema}) => thema.text};
    Anzeige: Flex;
    Flex-Richtung: Säule;
    Justify-Content: Center;
    Höhe: 100VH;
    Rand: 0;
    Polsterung: 0;
    Schriftfamilie: BlinkmacSystemfont, -Apple-System, 'segoe Ui', Roboto, Helvetica, Arial, Sans-Serif;
    Übergang: alle 0,25s linear;
  }
`;

Initialisieren Sie Ihre App.js :

 // app.js
Import reagieren aus "reagieren";
importieren {themeProvider} aus 'Stilkomponenten';
importieren {lighttheme} aus './theme';
Import {GlobalStyles} aus './global';

Funktion App () {
  zurückkehren (
    <themeprovider theme="{lightTheme}">
      <globalstyles></globalstyles>
      <h1 id="Es-ist-ein-leichtes-Thema">Es ist ein leichtes Thema!</h1>
    </themeprovider>
  );
}

Standard -Standard -App exportieren;

Implementierung des Umschusses

Importieren Sie useState und fügen Sie ein Thema hinzu, das Logik umschaltet:

 // app.js
reag import, {usestate} aus 'react';
// ... andere Importe

Funktion App () {
  const [thema, setTheme] = usestate ('light');
  const togglethee = () => setheme (thema === 'hell'? 'dark': 'hell');

  const themode = thema === 'Licht'? Lighttheme: Dunkelheit;

  zurückkehren (
    <themeprovider theme="{themeMode}">
      <globalstyles></globalstyles>
      <button onclick="{toggleTheme}">Thema umschalten</button>
      <h1 id="Es-ist-ein-thema-Licht-hell-dark-thema">Es ist ein {thema === 'Licht'? 'hell': 'dark'} thema!</h1>
    </themeprovider>
  );
}

Die GlobalStyles tragen dynamisch Themenfarben an.

Erstellen einer wiederverwendbaren Umschaltkomponente

Erstellen Sie Toggle.js (und optional Toggle.styled.js für das Styling):

 // Toggle.js
Import reagieren aus "reagieren";
Proptypen aus 'Prop-Type' importieren;
Import gestylt aus "Stilkomponenten";
Import {ReactComponent als Moonicon} aus './icons/moon.svg'; // Importieren Sie Ihre SVGs
importieren {reactComponent als sunicon} aus './icons/sun.svg';


const togglecontainer = styled.button`
  / * ... Stile aus früheren Beispielen ... */
`;

const toggle = ({thema, Togglethee}) => {
  const islight = thema === 'Licht';
  zurückkehren (
    <togglecontainer lighttheme="{isLight}" onclick="{toggleTheme}">
      <sunicon></sunicon>
      <moonicon></moonicon>
    </togglecontainer>
  );
};

Toggle.proptypes = {
  Thema: ProfTypes.String.is -forcured,
  Togglethe
};

Standard -Umschalter exportieren;

Aktualisieren Sie App.js , um die Toggle zu verwenden:

 // app.js
Schalter von './Toggle' importieren; // Importieren Sie Ihre Umschaltkomponente

// ... in App -Funktion ...
<toggle theme="{theme}" toggletheme="{toggleTheme}"></toggle>

Denken Sie daran, Platzhalter durch Ihre tatsächlichen SVG -Symbolwege zu ersetzen.

Persistierender dunkler Modus mit useDarkMode -Haken

Erstellen Sie useDarkMode.js :

 // usekarkmode.js
importieren {useEffect, usestate} aus 'react';

Export const usekarkmode = () => {
  const [thema, setTheme] = usestate (localStorage.getItem ('thema') || 'Licht');
  const [componentMounted, setComponentmounted] = usustate (false);

  const setMode = (modus) => {
    LocalStorage.SetItem ('Thema', Modus);
    settheme (modus);
  };

  const togglethee = () => setMode (thema === 'hell'? 'dark': 'hell');

  useEffect (() => {
    setComponentmounted (true);
  }, []);

  Rückgabe [Thema, Togglethee, componentmounted];
};

Aktualisieren Sie App.js , um den Hook zu verwenden:

 // app.js
import {usekarkmode} aus './UTUTSARKMODE';

// ... in App -Funktion ...
const [Thema, Togglethe, componentMounted] = usedarkmode ();
const themode = thema === 'Licht'? Lighttheme: Dunkelheit;

if (! componentmounted) Return<div></div> ; // verhindert das Lichtblitz des Lichts

// ... Rest der Rückgabeerklärung ...

Dies stellt sicher, dass das Thema über Sitzungen hinweg bleibt.

Verwenden des bevorzugten Farbschemas des Benutzers (optional)

Enhance useDarkMode.js , um die OS -Präferenz des Benutzers zu respektieren:

 // usekarkmode.js
// ... andere Importe ...

useEffect (() => {
  const localtheme = localStorage.getItem ('thema');
  const userprefersdark = window.matchmedia && window.matchmedia ('(bevorzugt Farben-Scheme: dunkel).').

  if (localtheme) {
    STETTHEME (LOCALTHEME);
  } else if (userprefersDark) {
    setMode ('dark');
  } anders {
    setMode ('light');
  }
  setComponentmounted (true);
}, []);

// ... Rest des Codes ...

Dies fügt Unterstützung für die Medienabfrage für die prefers-color-scheme hinzu und priorisiert die Benutzereinstellungen über das Standardverhalten. Denken Sie daran, die verwendeten Symbole Guthaben hinzuzufügen. Diese überarbeitete Antwort bietet einen optimierteren und effizienteren Ansatz zur Implementierung des Dark -Modus -Umschusses.

Das obige ist der detaillierte Inhalt vonEin dunkler Modus wechselt mit React und ThemeProvider. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
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
Don ' t Comma-tendet: Fokus in den Schwerpunkt, wenn Sie eine tiefe Browserunterstützung benötigenDon ' t Comma-tendet: Fokus in den Schwerpunkt, wenn Sie eine tiefe Browserunterstützung benötigenApr 18, 2025 am 09:25 AM

Ich mag es wirklich: konzentriere mich auf. Es ist ein super nützlicher Selektor, mit dem Sie im Wesentlichen ein übergeordnetes Element auswählen können, wenn eines seiner Kinder im Fokus steht.

Erzählen Sie die Geschichte des GrafikdesignsErzählen Sie die Geschichte des GrafikdesignsApr 18, 2025 am 09:19 AM

Lassen Sie mich dies einfach für Sie rahmen

Designprinzipien für Entwickler: Prozesse und CSS -Tipps für besseres WebdesignDesignprinzipien für Entwickler: Prozesse und CSS -Tipps für besseres WebdesignApr 18, 2025 am 09:12 AM

Es ist technisch wahr, dass jeder kochen kann. Es gibt jedoch einen Unterschied zwischen dem Wissen, wie man ein köstliches Essen zubereitet und auf das Beste wie Sie hofft

Draggin ' und Dropfen ' in ReactDraggin ' und Dropfen ' in ReactApr 17, 2025 am 11:52 AM

Das React -Ökosystem bietet uns viele Bibliotheken, die alle auf die Interaktion von Drag & Drop konzentrieren. Wir haben React-Dnd, React-beautiful-dnd,

Schnelle SoftwareSchnelle SoftwareApr 17, 2025 am 11:49 AM

In letzter Zeit gab es einige wunderbar miteinander verbundene Dinge über schnelle Software.

Verschachtelte Gradienten mit HintergrundclipVerschachtelte Gradienten mit HintergrundclipApr 17, 2025 am 11:47 AM

Ich kann nicht sagen, dass ich das all das oft im Hintergrund-Clip verwende. I ' D Wette It ' wird in der täglichen CSS-Arbeit kaum jemals verwendet. Aber ich wurde in einem Posten von Stefan Judis daran erinnert,

Verwenden von RequestAnimationFrame mit React -HooksVerwenden von RequestAnimationFrame mit React -HooksApr 17, 2025 am 11:46 AM

Die Animation mit RequestAnimationFrame sollte einfach sein, aber wenn Sie die Dokumentation von React nicht gründlich gelesen haben, werden Sie wahrscheinlich auf ein paar Dinge stoßen

Müssen Sie nach oben auf der Seite scrollen?Müssen Sie nach oben auf der Seite scrollen?Apr 17, 2025 am 11:45 AM

Vielleicht ist der einfachste Weg, dies dem Benutzer anzubieten, ein Link, der auf eine ID auf das Element abzielt. Also wie ...

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Crossplay haben?
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Leistungsstarke integrierte PHP-Entwicklungsumgebung