„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Sehen Sie sich Animationen für Übergangsthemen an

Sehen Sie sich Animationen für Übergangsthemen an

Veröffentlicht am 04.11.2024
Durchsuche:967

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

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

  1. Fügen Sie das CSS hinzu
  /* 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%);
    }
  }

  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";
  }, []);

in SSR kann es direkt im HTML-Tag gesetzt werden

  1. Verbinden Sie Ihre Theme-Änderungsfunktion mit einer documnet.startViewTransition, 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);
      });
    }
  }

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

      

Reaktionsbeispiel

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

Freigabeerklärung Dieser Artikel ist abgedruckt unter: https://dev.to/tigawanna/view-transition-theme-animations-8n1?1 Bei Verstößen wenden Sie sich bitte an [email protected], um ihn zu löschen
Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3