У меня есть два компонента. Мне нужно получить даты и отправить их, чтобы забрать. В компоненте MainPage я добавляю состояние для значений дат. В компоненте InputForm я добавляю ответный сборщик данных.
Когда пользователь устанавливает даты для сборщиков данных, эти значения следует отправлять для извлечения в формате 'dd.mm.yyyy' или 'yyyy-mm-dd' (я использую dateFormat для изменения).
В результате у меня есть этот код для MainPage :
import React, { PropTypes, Component } from 'react';
import dateFormat from 'dateformat';
class ReportPage extends Component {
constructor(props) {
super(props);
this.state = {
date1: new Date(),
date2: new Date()
};
this.onHandleFetch = this.onHandleFetch.bind(this);
this.onChangeInputDate1 = this.onChangeInputDate1.bind(this);
this.onChangeInputDate2 = this.onChangeInputDate2.bind(this);
this.checkInputs = this.checkInputs.bind(this);
}
handleShowClick() { // if button clicked
if (this.checkInputs()) { // if dates not null
this.onHandleFetch();
}
}
checkInputs() {
if (this.state.date1 === null || this.state.date2 === null) {
return false;
}
return true;
}
onChangeInputDate1(d1) {
console.log(dateFormat(d1, 'isoDate')); // format yyyy-mm-dd
this.setState({
date1: d1
});
}
onChangeInputDate2(d2) {
console.log(dateFormat(d2, 'isoDate'));
this.setState({
date2: d2
});
}
onHandleFetch() {
fetch(`${Config.baseUrl}/find/${dateFormat(this.state.date1, 'isoDate')}/
${dateFormat(this.state.date2, 'isoDate')}`, {
method: 'GET'
})
...
}
render() {
return (
<div>
<InputForm
handleChangeInputDate1={this.onChangeInputDate1} handleChangeInputDate2={this.onChangeInputDate2}
date1={this.state.date1} date2={this.state.date2}
/>
)
...
}
InputForm
import React, { PropTypes, Component } from 'react';
import DatePicker from 'react-date-picker';
const propTypes = {
date1: PropTypes.string,
date2: PropTypes.string,
handleChangeInputDate1: PropTypes.func,
handleChangeInputDate2: PropTypes.func
};
class InputForm extends Component {
constructor(props) {
super(props);
this.handleOnChange1 = this.handleOnChange1.bind(this);
this.handleOnChange2 = this.handleOnChange2.bind(this);
}
handleOnChange1(date1) {
this.props.handleChangeInputDate1(date1);
}
handleOnChange2(date2) {
this.props.handleChangeInputDate2(date2);
}
render() {
return (
<form>
...
<DatePicker onChange={this.handleOnChange1}
value={this.props.date1}
/>
<DatePicker onChange={this.handleOnChange2}
value={this.props.date2}
/>
...
</form>
);
}
}
В результате у меня появляется эта ошибка в консоли:
Объекты недопустимы в качестве дочерних элементов React (найдено: ср. 17 октября 2018 г.
00:00:00 GMT + 0500 (Екатеринбург, стандартное время)).
Как я могу это исправить?