2016-03-31 09:40:55 +08:00
|
|
|
---
|
2019-12-11 23:32:19 +08:00
|
|
|
order: 99
|
2016-09-08 14:09:36 +08:00
|
|
|
title:
|
2016-11-11 12:08:18 +08:00
|
|
|
zh-CN: 自定义日期范围选择
|
|
|
|
en-US: Customized Range Picker
|
2019-12-11 23:32:19 +08:00
|
|
|
debug: true
|
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
|
|
|
|
|
2016-11-11 12:08:18 +08:00
|
|
|
当 `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
|
|
|
|
|
2017-12-06 09:35:34 +08:00
|
|
|
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
|
2020-07-30 19:17:34 +08:00
|
|
|
import { DatePicker, Space } from 'antd';
|
2015-10-22 17:27:53 +08:00
|
|
|
|
2022-05-11 19:43:54 +08:00
|
|
|
export default () => {
|
|
|
|
const [state, setState] = React.useState({
|
2016-11-11 12:08:18 +08:00
|
|
|
startValue: null,
|
|
|
|
endValue: null,
|
|
|
|
endOpen: false,
|
2022-05-11 19:43:54 +08:00
|
|
|
});
|
2016-11-11 12:08:18 +08:00
|
|
|
|
2022-05-11 19:43:54 +08:00
|
|
|
const disabledStartDate = startValue => {
|
|
|
|
const { endValue } = state;
|
2016-11-11 12:08:18 +08:00
|
|
|
if (!startValue || !endValue) {
|
2015-10-22 17:27:53 +08:00
|
|
|
return false;
|
|
|
|
}
|
2016-11-11 12:08:18 +08:00
|
|
|
return startValue.valueOf() > endValue.valueOf();
|
2019-05-07 14:57:32 +08:00
|
|
|
};
|
2016-11-11 12:08:18 +08:00
|
|
|
|
2022-05-11 19:43:54 +08:00
|
|
|
const disabledEndDate = endValue => {
|
|
|
|
const { startValue } = state;
|
2016-11-11 12:08:18 +08:00
|
|
|
if (!endValue || !startValue) {
|
2015-10-28 18:35:56 +08:00
|
|
|
return false;
|
|
|
|
}
|
2018-01-30 16:00:49 +08:00
|
|
|
return endValue.valueOf() <= startValue.valueOf();
|
2019-05-07 14:57:32 +08:00
|
|
|
};
|
2016-11-11 12:08:18 +08:00
|
|
|
|
2022-05-11 19:43:54 +08:00
|
|
|
const onChange = (field, value) => {
|
|
|
|
setState({
|
|
|
|
...state,
|
2015-10-22 17:27:53 +08:00
|
|
|
[field]: value,
|
|
|
|
});
|
2019-05-07 14:57:32 +08:00
|
|
|
};
|
2016-11-11 12:08:18 +08:00
|
|
|
|
2022-05-11 19:43:54 +08:00
|
|
|
const onStartChange = value => {
|
|
|
|
onChange('startValue', value);
|
2019-05-07 14:57:32 +08:00
|
|
|
};
|
2016-11-11 12:08:18 +08:00
|
|
|
|
2022-05-11 19:43:54 +08:00
|
|
|
const onEndChange = value => {
|
|
|
|
onChange('endValue', value);
|
2019-05-07 14:57:32 +08:00
|
|
|
};
|
2016-11-11 12:08:18 +08:00
|
|
|
|
2022-05-11 19:43:54 +08:00
|
|
|
const handleStartOpenChange = open => {
|
2016-06-15 17:46:25 +08:00
|
|
|
if (!open) {
|
2022-05-11 19:43:54 +08:00
|
|
|
setState({ ...state, endOpen: true });
|
2016-06-15 17:46:25 +08:00
|
|
|
}
|
2019-05-07 14:57:32 +08:00
|
|
|
};
|
2016-11-11 12:08:18 +08:00
|
|
|
|
2022-05-11 19:43:54 +08:00
|
|
|
const handleEndOpenChange = open => {
|
|
|
|
setState({ ...state, endOpen: true });
|
2019-05-07 14:57:32 +08:00
|
|
|
};
|
2016-11-11 12:08:18 +08:00
|
|
|
|
2022-05-11 19:43:54 +08:00
|
|
|
return (
|
|
|
|
<Space>
|
|
|
|
<DatePicker
|
|
|
|
disabledDate={disabledStartDate}
|
|
|
|
showTime
|
|
|
|
format="YYYY-MM-DD HH:mm:ss"
|
|
|
|
value={state.startValue}
|
|
|
|
placeholder="Start"
|
|
|
|
onChange={onStartChange}
|
|
|
|
onOpenChange={handleStartOpenChange}
|
|
|
|
/>
|
|
|
|
<DatePicker
|
|
|
|
disabledDate={disabledEndDate}
|
|
|
|
showTime
|
|
|
|
format="YYYY-MM-DD HH:mm:ss"
|
|
|
|
value={state.endValue}
|
|
|
|
placeholder="End"
|
|
|
|
onChange={onEndChange}
|
|
|
|
open={state.endOpen}
|
|
|
|
onOpenChange={handleEndOpenChange}
|
|
|
|
/>
|
|
|
|
</Space>
|
|
|
|
);
|
|
|
|
};
|
2019-05-07 14:57:32 +08:00
|
|
|
```
|