Heim > Web-Frontend > CSS-Tutorial > Hauptteil

Sehen Sie sich Animationen für Übergangsthemen an

Patricia Arquette
Freigeben: 2024-09-25 17:11:42
Original
953 Leute haben es durchsucht

View transition theme animations

Fügen Sie einen coolen Effekt hinzu, wenn Sie mithilfe von CSS und Ansichtsübergängen vom hellen in den dunklen Modus wechseln

kopiert von @jhey auf Twitter

[!NOTE]
Dies setzt voraus, dass Sie Ihren Dunkellichtmodus bereits mit einer Funktion zum Aktualisieren Ihres Themas eingerichtet haben

  1. CSS hinzufügen
  /* Angled */
  [data-style='angled']::view-transition-old(root) {
    animation: none;
    z-index: -1;
  }

  [data-style='angled']::view-transition-new(root) {
    animation: unclip 1s;
    clip-path: polygon(-100vmax 100%, 100% 100%, 100% -100vmax);
  }

  @keyframes unclip {
    0% {
      clip-path: polygon(100% 100%, 100% 100%, 100% 100%);
    }
  }

Nach dem Login kopieren
  1. Stellen Sie sicher, dass das Attribut data-style="angled" für das Stammelement festgelegt ist In SPA React verwenden wir einen useEffect-Hook
  useEffect(() => {
    // set the data-style attribute
    document.documentElement.dataset.style = "angled";
  }, []);
Nach dem Login kopieren

in SSR kann es direkt im HTML-Tag eingestellt werden

  1. Schließen Sie Ihre Theme-Änderungsfunktion in eine documnet.startViewTransition ein, um den Ansichtsübergang zu starten
  function transitionColors() {
    if (typeof window !== "undefined") {
      document.startViewTransition(() => {
        const newTheme = theme  === "light" ? "dark" : "light";
        document.documentElement.dataset.theme = newTheme;
        updateTheme(newTheme);
      });
    }
  }

Nach dem Login kopieren

Weitere Übergangsstile können hinzugefügt werden, indem die entsprechende CSS-Datei eingebunden und das richtige Datenstilattribut hinzugefügt wird

      <select
      className="select select-bordered select-sm max-w-xs"
        onChange={(e) =>
          (document.documentElement.dataset.style = e.target.value)
        }
      >
        <option value="default">Default</option>
        <option value="vertical">Vertical</option>
        <option value="wipe">Wipe</option>
        <option value="angled">Angled</option>
        <option value="flip">Flip</option>
        <option value="slides">Slides</option>
      </select>
Nach dem Login kopieren

Reaktionsbeispiel

Wenn Ihnen diese Art von CSS-Tricks gefällt, sollten Sie jhey folgen

Das obige ist der detaillierte Inhalt vonSehen Sie sich Animationen für Übergangsthemen an. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:dev.to
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
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!