Я пытаюсь создать анимацию для перемещения дочернего элемента из одного родительского элемента в другой с помощью React.
Пользователь должен иметь возможность щелкнуть элемент и увидеть, как он перемещается в другой элемент div.
Я сделал простой демонстрационный компонент (без анимации), чтобы показать, что я имею в виду.При щелчке по элементу состояние обновляется, и элементы повторно отображаются в правильном месте.
class App extends React.Component {
state = {
list: ['Alice', 'Bob', 'Charlie', 'David', 'Emily', 'Frank'],
top: [0, 1, 2],
bottom: [3, 4, 5]
}
moveDown = (item) => {
let { top, bottom } = this.state
this.setState({
top: top.filter(x => x !== item),
bottom: [...bottom, item]
})
}
moveUp = (item) => {
let { top, bottom } = this.state
this.setState({
top: [...top, item],
bottom: bottom.filter(x => x !== item)
})
}
render() {
let { top, bottom, list } = this.state
return (
<div style={{
display: 'flex',
flexDirection: 'column',
justifyContent: 'space-between',
alignItems: 'center',
height: '90vh',
width: '100%'
}}>
<div>
{top.map((item) =>
<div
onClick={() => this.moveDown(item)}
style={{color:'red'}}>{list[item]}</div>
)}
</div>
<div>
{bottom.map((item) =>
<div
onClick={() => this.moveUp(item)}
style={{color:'green'}}>{list[item]}</div>
)}
</div>
</div>
)
}
}
Демонстрация Codepen: https://codepen.io/ee92/pen/LqrBjL?editors=0010
Большое спасибо и заранее благодарим за любую помощь или совет о том, как добиться этой анимации div-to-div.