Heim  >  Artikel  >  Web-Frontend  >  Übergangsanimation in der React.js-App anzeigen

Übergangsanimation in der React.js-App anzeigen

王林
王林Original
2024-08-23 14:31:15952Durchsuche

View Transition Animation in React.js App

Neulich möchte ich eine schnelle Animation zum Entfernen von Elementen aus der Liste für die Website erstellen. Überspringen Sie dieses Mal die React Transition Group, probieren Sie den neuen View Transition aus und sparen Sie Zeit.

Warum viel Code schreiben, wenn nur wenige Codes funktionieren.

Transition API nur Chrome anzeigen, aber mir ist das egal.

Der Kernpunkt ist document.startViewTransition.

Aber es muss ein DOM vor dem Status und nach dem Status eingerichtet werden, aber React.js erlaubt das nicht.

React.js reaktiv. Nicht synchron. document.startViewTransition muss synchron sein.

Fragen Sie Google Learn:

import { flushSync } from "react-dom";

flushSync(() => setState(...));

Ich schreibe Hook:

import { useState } from "react";
import { flushSync } from "react-dom";

export const useViewTransition =
  typeof document !== "undefined" && "startViewTransition" in document
    ? <T>(newValue: T) => {
        const [value, setValue] = useState<T>(newValue);
        if (value !== newValue) {
          document.startViewTransition(() => {
            flushSync(() => {
              setValue(newValue);
            });
          });
        }
        return value;
      }
    : <T>(value: T) => value;

Bei Verwendung von useQuery

const { data: newMsgs } = useQuery({
  queryKey: ["msgs"],
  queryFn: msgs.all(25)
});

const msgs = useViewTransition(newMsgs);

return (
  <ol>
    {msgs?.map(item => (
      <li 
        key={item.id} 
        style={{
          viewTransitionName: "msg-" + item.id,
          viewTransitionClass: "mymsg",
        }}
      >
        {item.title}
      </li>
    ))}
  </ol>
);

Wenn Sie nun die Abfrage aktualisieren, rufen Sie document.startViewTransition auf und setzen Sie dann setState.

Benötigen Sie globales CSS

Ich füge global.css hinzu:

@supports (view-transition-name: none) {
  ::view-transition-group(root) {
    animation-duration: 0s;
  }
  ::view-transition-group(.mymsg) {
    animation-duration: 0.4s;
  }
}

Dies sagt Chrome: Übertragen Sie nicht die gesamte Seite, sondern nur die Elemente der Liste.

Jetzt funktioniert die Animation der Nachrichtenliste. Sehr schön.

Das obige ist der detaillierte Inhalt vonÜbergangsanimation in der React.js-App anzeigen. 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