初始化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: 使用yarn初始化Ant Design Pro时出现错误可能有多种原因,下面给出几种常见的解决方法: 1. 确保安装了最新版本的Node.js和Yarn:首先检查已经安装了最新版本的Node.js和Yarn,可以通过在终端运行`node -v`和`yarn -v`来确认版本。如果版本过低,可以升级到最新版本。 2. 清除Yarn缓存:在终端中运行`yarn cache clean`命令来清除Yarn的缓存,然后重新运行`yarn`命令来初始化Ant Design Pro。 3. 检查网络连接:确保网络连接稳定,如果遇到网络问题可能会导致无法正常下载依赖包。可以先尝试使用`yarn config get proxy`命令来检查是否设置了代理,如果设置了代理可能需要将其关闭或者配置正确。 4. 检查依赖包版本:在初始化Ant Design Pro时,可能会遇到依赖包版本不兼容的问题。可以尝试更新依赖包或者在初始化时添加`--ignore-engines`参数来忽略引擎检查。 需要注意的是,以上解决方法只是针对一般情况的建议,具体情况可能因个人电脑环境和网络环境等因素而异。 ### 回答2: 使用yarn初始化ant design pro时报错可能是因为以下几个原因: 1. 网络问题:请确保您的网络连接正常,因为yarn初始化依赖于网络下载文件。 2. yarn版本问题:请确保您安装的yarn版本符合ant design pro的要求。您可以尝试升级或降级yarn版本,或者使用其他包管理工具,如npm。 3. 缓存问题:有时候yarn会使用缓存文件来安装依赖项。您可以尝试清除yarn的缓存并重新运行初始化命令,例如运行`yarn cache clean`命令。 4. 项目路径问题:请确保您在正确的项目文件夹路径下进行初始化操作,并且该文件夹没有其他冲突的文件或文件夹。 5. 其他依赖项冲突:有可能是因为其他依赖项的版本冲突导致报错。您可以尝试手动安装依赖项,或者通过更改项目的依赖项版本来解决冲突。 如果以上方法都不起作用,建议您查看报错信息的详细内容,根据报错信息来进一步排查问题并解决。您还可以尝试在开发者社区或相关论坛上寻求帮助,让更多有经验的开发者帮助您解决问题。 ### 回答3: 使用yarn初始化Ant Design Pro时,如果出现报错,可以尝试以下解决方法: 1. 确保已经安装了Node.js和Yarn,可以通过在命令行中运行`node -v`和`yarn -v`来检查版本。如果未安装,请下载并安装最新版本。 2. 检查网络连接,确保能够正常访问互联网。有时,下载依赖包需要从远程仓库获取,如果网络不稳定,可能会导致报错。 3. 尝试清除Yarn的缓存,有时缓存的内容可能会导致问题。可以在命令行中运行`yarn cache clean`来清除缓存。 4. 如果报错信息中有具体的错误提示,可以根据提示信息进行排查。有时可能是由于依赖版本不兼容或者缺少某些依赖导致的。 5. 可以尝试使用npm来初始化Ant Design Pro,有时使用不同的包管理工具可能会有不同的结果。 如果以上方法都不能解决问题,可以尝试在Ant Design Pro的GitHub页面上查找是否有类似的问题或者提问。在那里,可以找到开发者社区并与其他开发者讨论问题,或者提交一个新的issue以获得更多帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值