ant-design/components/date-picker/demo/start-end.md

102 lines
2.3 KiB
Markdown
Raw Normal View History

2016-03-31 09:40:55 +08:00
---
order: 6
2016-09-08 14:09:36 +08:00
title:
zh-CN: 自定义日期范围选择
en-US: Customized Range Picker
2016-03-31 09:40:55 +08:00
---
2015-10-22 17:27:53 +08:00
2016-06-19 11:17:09 +08:00
## zh-CN
`RangePicker` 无法满足业务需求时,可以使用两个 `DatePicker` 实现类似的功能。
2019-05-07 14:57:32 +08:00
> - 通过设置 `disabledDate` 方法,来约束开始和结束日期。
> - 通过 `open` `onOpenChange` 来优化交互。
2015-10-22 17:27:53 +08:00
2016-06-19 11:17:09 +08:00
## en-US
When `RangePicker` does not satisfied your requirements, try to implement similar functionality with two `DatePicker`.
2016-06-19 11:17:09 +08:00
2019-05-07 14:57:32 +08:00
> - Use the `disabledDate` property to limit the start and end dates.
> - Improve user experience with `open` and `onOpenChange`.
```jsx
import { DatePicker } from 'antd';
2015-10-22 17:27:53 +08:00
class DateRange extends React.Component {
state = {
startValue: null,
endValue: null,
endOpen: false,
};
2019-05-07 14:57:32 +08:00
disabledStartDate = startValue => {
2019-06-19 19:09:08 +08:00
const { endValue } = this.state;
if (!startValue || !endValue) {
2015-10-22 17:27:53 +08:00
return false;
}
return startValue.valueOf() > endValue.valueOf();
2019-05-07 14:57:32 +08:00
};
2019-05-07 14:57:32 +08:00
disabledEndDate = endValue => {
2019-06-19 19:09:08 +08:00
const { startValue } = this.state;
if (!endValue || !startValue) {
2015-10-28 18:35:56 +08:00
return false;
}
return endValue.valueOf() <= startValue.valueOf();
2019-05-07 14:57:32 +08:00
};
onChange = (field, value) => {
2015-10-22 17:27:53 +08:00
this.setState({
[field]: value,
});
2019-05-07 14:57:32 +08:00
};
2019-05-07 14:57:32 +08:00
onStartChange = value => {
2016-03-30 17:06:19 +08:00
this.onChange('startValue', value);
2019-05-07 14:57:32 +08:00
};
2019-05-07 14:57:32 +08:00
onEndChange = value => {
2016-03-30 17:06:19 +08:00
this.onChange('endValue', value);
2019-05-07 14:57:32 +08:00
};
2019-05-07 14:57:32 +08:00
handleStartOpenChange = open => {
if (!open) {
this.setState({ endOpen: true });
}
2019-05-07 14:57:32 +08:00
};
2019-05-07 14:57:32 +08:00
handleEndOpenChange = open => {
this.setState({ endOpen: open });
2019-05-07 14:57:32 +08:00
};
2015-10-22 17:27:53 +08:00
render() {
const { startValue, endValue, endOpen } = this.state;
return (
<div>
<DatePicker
disabledDate={this.disabledStartDate}
showTime
format="YYYY-MM-DD HH:mm:ss"
value={startValue}
2016-09-29 14:35:33 +08:00
placeholder="Start"
onChange={this.onStartChange}
onOpenChange={this.handleStartOpenChange}
/>
<DatePicker
disabledDate={this.disabledEndDate}
showTime
format="YYYY-MM-DD HH:mm:ss"
value={endValue}
2016-09-29 14:35:33 +08:00
placeholder="End"
onChange={this.onEndChange}
open={endOpen}
onOpenChange={this.handleEndOpenChange}
/>
</div>
);
}
}
2015-10-22 17:27:53 +08:00
ReactDOM.render(<DateRange />, mountNode);
2019-05-07 14:57:32 +08:00
```