Компонент React Animation не будет обновляться
Я использую оболочку React для библиотеки анимации anime.js и пытаюсь создать приложение, которое принимает пользовательский ввод, а затем анимирует div на основе ввода
(Картинка для наглядности)
Он начинается с простого подвижного квадрата, но после нажатия кнопки "Анимация" он обновляется до того, что ввел пользователь.
Однако, когда я нажимаю кнопку анимации, div просто полностью исчезает, а если я нажимаю на нее второй раз, весь родительский компонент и все исчезают! Это оставляет меня с этим сообщением об ошибке, однако в консоли.
Я провел тестирование, и реквизиты передаются объекту outputDivProps в AnimationOutput.jsx, и они верны, но div просто не обновляется должным образом.
Родительский компонент (Animation.jsx)
Компоненты AnimationForm.jsx & AnimationOutput.jsx
import React, {Component} from 'react';
import {Segment} from 'semantic-ui-react';
import AnimationForm from './AnimationForm.jsx';
import AnimationOutput from './AnimationOutput.jsx';
import BoxChanger from './BoxChanger.jsx';
export default class Animation extends Component {
constructor(props) {
super(props);
this.state = {
boxColor: 'white',
boxShape: 'square',
boxDiration: 3,
boxTranslate: '50vw',
boxEasing: 'linear',
boxDelay: 0
};
}
updateAni = (boxColor, boxShape, boxDiration, boxTranslate, boxEasing, boxDelay) => {
console.log('updateAni: ' + boxColor, boxShape, boxDiration, boxTranslate, boxEasing, boxDelay);
this.setState({
boxColor: boxColor,
boxShape: boxShape,
boxDiration: boxDiration,
boxTranslate: boxTranslate,
boxEasing: boxEasing,
boxDelay: boxDelay
});
}
render() {
const {boxColor, boxShape, boxDiration, boxTranslate, boxEasing, boxDelay} = this.state;
return (<Segment inverted>
<h2>Animation Creator!</h2>
<AnimationForm aniUpdate={this.updateAni}/>
<h3>Box Animations!</h3>
<AnimationOutput boxColor={boxColor} boxShape={boxShape} boxDiration={boxDiration * 1000} boxTranslate={boxTranslate} boxEasing={boxEasing} boxDelay={boxDelay * 1000}/>
<BoxChanger/>
</Segment>
);
}
}
Компонент формы (AnimationForm.jsx)
import React, {Component} from 'react';
import {Form, Input, Button, Select, Radio} from 'semantic-ui-react';
export default class AnimationForm extends Component {
state = {
boxColorValue: '',
boxShapeValue: '',
boxDirationValue: '',
boxTranslateValue: '',
boxEasingValue: '',
boxDelayValue: ''
};
handleChange = (e, {name, value}) => this.setState({[name]: value});
handleSubmit = () => {
const {boxColorValue, boxShapeValue, boxDirationValue, boxTranslateValue, boxEasingValue, boxDelayValue} = this.state;
this.props.aniUpdate(boxColorValue, boxShapeValue, boxDirationValue, boxTranslateValue, boxEasingValue, boxDelayValue);
}
render() {
const {boxColorValue, boxDirationValue, boxTranslateValue, boxDelayValue} = this.state;
const options = [/* Options for dropdown */]
return (<Form inverted className='box-animation-form' size={'big'}>
<Form.Group widths='equal'>
<Form.Field control={Input} name='boxColorValue' value={boxColorValue} label='Color' placeholder='exp. #ffffff or white' onChange={this.handleChange}/>
<Form.Field control={Input} name='boxDirationValue' value={boxDirationValue} label='Diration' placeholder='exp. 2 or 5 (seconds)' onChange={this.handleChange}/>
<Form.Field control={Select} name='boxEasingValue' label='Transition Type' value={options.value} options={options} placeholder='Types' onChange={this.handleChange}/>
</Form.Group>
<Form.Group inline>
<label>Shape</label>
<Form.Field control={Radio} label='Square' checked={this.state.boxShapeValue === 'square'} onClick={() => this.setState({boxShapeValue: 'square'})}/>
<Form.Field control={Radio} label='Circle' checked={this.state.boxShapeValue === 'circle'} onClick={() => this.setState({boxShapeValue: 'circle'})}/>
<Form.Field control={Radio} label='Triangle' checked={this.state.boxShapeValue === 'triangle'} onClick={() => this.setState({boxShapeValue: 'triangle'})}/>
</Form.Group>
<Form.Group widths='equal'>
<Form.Field control={Input} name='boxTranslateValue' value={boxTranslateValue} label='Want it to move?' placeholder='exp. 200 or 200px' onChange={this.handleChange}/>
<Form.Field control={Input} name='boxDelayValue' value={boxDelayValue} label='Delay' placeholder='exp. 1 or 2 (seconds)' onChange={this.handleChange}/>
</Form.Group>
<Button inverted color='green' onClick={this.handleSubmit}>Animate!</Button>
</Form>);
}
}
Компонент анимационного блока (AnimationOutput.jsx)
-Я думаю, что проблема здесь!
import React from 'react';
import Anime from 'react-anime';
const AnimationOutput = (props) => {
console.log('AnimationOutput: ' + props.boxColor, props.boxShape, props.boxDiration, props.boxTranslate, props.boxEasing, props.boxDelay);
let outputDivProps = {
easing: 'linear',
loop: true,
direction: 'alternate',
duration: props.boxDiration,
translateX: props.boxTranslate
};
let outputDivStyle = {
width: 100,
height: 100,
backgroundColor: props.boxColor
};
console.log(outputDivProps)
return (<div className='animation-output-box'>
<Anime {...outputDivProps}>
<div style={outputDivStyle}></div>
</Anime>
</div>);
}
export default AnimationOutput;