React Animation For Moving An Element From One Parent To Another
Solution 1:
No it's not possible
It's not possible to animate in that way because the DOM thinks you're removing a div and then adding a new div. Even though it's the same div to you, the DOM doesn't have that context. Animations are controlled by changes to CSS, not HTML. 
...but here's how to do it
If you actually need both lists to stay in different divs the best you can do is either:
- Animate the 
old itemto thenew itemposition, then delete theold itemand show thenew item. - Remove the 
old itemand create anew itemwhere theold itemwas and move it to thenew itemposition. 
Same concept, two ways of doing it.
I modified your existing sample to show a simplified version of option 2. Note that there are a number of animation decisions to make like what happens when the list gets smaller, how should the items change from red to green, etc., and I didn't try and objectively solve them. Also, this would be much easier if you could have all the items for both lists in one div, and control their positions absolutely. But if they need to end up in separate divs...
https://codepen.io/sallf/pen/VgBwQr?editors=0010
What's going on
- Adding a 
transitionto.itemwe can make the animation happen when we make adjustments to thetransformproperty. - On item click we update our lists in state and add...
 transition.itemto know which item is animating...transition.startTopto know the offsetyposition the item should start at relative to the bottom of the list it's moving to, and...transition.startAnimas a flag to control the animation.- Since 
transitions need something to change before they'll animate, we usesetTimeoutto delay the change oftransition.startAnimwhich basically causes the animation from the computed position, back to0. 
Post a Comment for "React Animation For Moving An Element From One Parent To Another"