Ich versuche herauszufinden, wie man bewegte reaktive Komponenten von einem zum anderen animiert. Nehmen Sie zum Beispiel ein sehr einfaches, aber interessantes Kartenspiel: Sie können jede Karte auf ein Deck legen oder die oberste Karte vom Stapel nehmen.Animiere Bewegung der React-Komponente von einem zum anderen
Um es funktionieren zu lassen, habe ich 4 Klassen - <Board>
, die zwei <Card Collection>
enthält: "Deck" und "Hand" -Komponenten. Im Konstruktor generieren sie CardModel-Elemente und rendern sie über die Komponente <Card>
. <CardCollection>
Komponente hat spezielle onCardClick
Prop, die Callback-Funktion übernimmt. In meinem Fall ist es onCardClick={/*this is equal to <Board>*/ this.transferCard("Hand")}
Board.transferCard
nimmt angeklickt CardModel aus dem Zustand einer Komponente und schiebt es zu einem anderen.
Das Problem ist Animation - Ich möchte Karte fliegen, vorzugsweise durch Mitte (optional!) Von altem Ort zu neuen. Ich bin in der Lage, die neu erstellte Karte an "neuen Ort" an der gleichen Stelle wie die alte Komponente zu platzieren, aber da ich nur versucht habe, React zu lernen, bin ich mir nicht sicher, wo genau ich anfangen soll. Umbruch in ReactCSSTransitionGroup? Übergeben Sie die Eigenschaft "animate: from {x, y} to {x, y}" an <CardCollection>
?
Also die volle Frage ist, was ist die allgemeinste, kontrollierbar und "reagieren" Weg, um diese Situation zu animieren?
JSFiddle Basis Frage Version: https://jsfiddle.net/fen1kz/6qxpzmm6/
JSFiddle erste Animation Prototypversion: https://jsfiddle.net/fen1kz/6qxpzmm6/1
ich hier nicht <this.state.animations.map...
mag. Auch die Animationskomponente sieht für mich wie ein Greuel aus, ich bin mir nicht sicher, ob das der gute Architekturstil für React ist.
Ich habe Abschnitt aktualisiert Beispiele. Gebrauchte Velocity.js, wie Sie sehen - das ist immer noch eine inakzeptable Lösung. Mehrere Karten funktionieren nicht. Was mich auch betrifft, ist, dass ich Dom manipuliere, ohne es zu wissen. nicht sicher, ob es gut ist – Fen1kz