初始化antDesign RangePicker默认选择日期及限制日期可选范围

主要做了两个设置:

1、初始化默认选择日期;

2、限制日期可选范围(限制最大可选范围是最近6个月)

具体实现代码出下:

import React, { PureComponent } from 'react';
import moment from 'moment';
import { 
  Form, 
  Modal,
  DatePicker,
} from 'antd';

const FormItem = Form.Item;
const { RangePicker } = DatePicker;

@Form.create()
class ExportModal extends PureComponent {

  // 表单提交
  okHandle = () => {
    const { handleExportByTime, form } = this.props;
    form.validateFields((err, fieldsValue) => {
      const rangeValue = fieldsValue['range-picker'];
      if (err) return;
      const values ={
        ...fieldsValue,
        'date': [rangeValue[0].format('YYYY-MM-DD'), rangeValue[1].format('YYYY-MM-DD')],
      }
      // 重置表单
      form.resetFields();
      handleExportByTime(values);
    });
  };

  // 不可选择的时间段
  disabledDate = current => current && current > moment().endOf('day') || current < moment().subtract(6, 'months');

  render() {
    const {
      form: { getFieldDecorator },
      handleModalVisible,
      submitting,
      modalVisible,
    } = this.props;

    const formItemLayout = {
      labelCol: { span: 4 },
      wrapperCol: { span: 14 }
    };

    // 初始化日期显示 
    const defaultSelectDate = {
      startDate: moment().subtract(1, 'weeks'),
      endDate: moment().endOf('day')
    }

    return (
      <Modal
        destroyOnClose
        title='按时间段导出'
        centered
        keyboard={false}
        maskClosable={false}
        visible={modalVisible}
        confirmLoading={submitting}
        onOk={this.okHandle}
        onCancel={() => handleModalVisible()}
      >
        <FormItem {...formItemLayout} label='时间段' extra='最长可导出最近6个月数据'>
          {getFieldDecorator('range-picker',{
            initialValue: [defaultSelectDate.startDate, defaultSelectDate.endDate]
          })(
            <RangePicker disabledDate={this.disabledDate} />
          )}
        </FormItem>
      </Modal>
    );
  }
}
export default ExportModal;

 

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值