我正在使用 react-date 尝试设置所选日期的状态:
<DateRangePicker
...
onDatesChange={({ startDate, endDate }) => this.setState({ startDate,
endDate })}
...
/> // PropTypes.func.isRequired
如果它位于状态所在的主要组件中,这可以正常工作,但是我现在在该组件的子组件中有 DateRangePicker,所以我不能只从子组件中设置状态。
我尝试编写一个位于父组件中的函数来设置状态,但这不起作用:
在子组件中:
<DateRangePicker
...
onDatesChange={({ startDate, endDate }) => props.onDatesChange({ startDate,
endDate })}
...
/>
在父组件中:
onDatesChange = (startDate, endDate) => {
this.setState({
startDate,
endDate
})
};
尽管这适用于 DateRangePicker 中设置父级状态的另一个参数:
在孩子身上:
<DateRangePicker
...
onFocusChange={props.onFocusChange}
...
/>
在父级中:
onFocusChange = focusedInput => this.setState({ focusedInput })