Übergangsanimation in der React.js-App anzeigen

王林
Freigeben: 2024-08-23 14:31:15
Original
714 Leute haben es durchsucht

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 Loscode schreiben, wenn nur wenige Codes funktionieren.

Übergangs-API nur für 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, lernen Sie:

import { flushSync } from "react-dom"; flushSync(() => setState(...));
Nach dem Login kopieren

Ich schreibe Hook:

import { useState } from "react"; import { flushSync } from "react-dom"; export const useViewTransition = typeof document !== "undefined" && "startViewTransition" in document ? (newValue: T) => { const [value, setValue] = useState(newValue); if (value !== newValue) { document.startViewTransition(() => { flushSync(() => { setValue(newValue); }); }); } return value; } : (value: T) => value;
Nach dem Login kopieren

Bei Verwendung von useQuery

const { data: newMsgs } = useQuery({ queryKey: ["msgs"], queryFn: msgs.all(25) }); const msgs = useViewTransition(newMsgs); return ( 
    {msgs?.map(item => (
  1. {item.title}
  2. ))}
);
Nach dem Login kopieren

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

auf

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

Dies teilt Chrome mit: Ü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!

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 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!