关注互联网应用及运维技术的个人博客

antd-DatePicker组件获取时间值,以及相关设置

DatePicker组件默认语言是英语,需要设置为中文的话,需要安装moment。

import moment from "moment";
import "moment/locale/zh-cn"

format属性,设置日期的格式,如“2020-02-28”。

设置日期
  1. 选择日期是今天之前【包含今天】
    需要和moment搭配应用
        // 设置默认的起始日期
        const disabledDate = (current) => {
            console.log(current)
            return current > moment().startOf('day');
        }
        <DatePicker disabledDate={disabledDate}

效果如下图:

如果是选择今天之后的日期【包含今天】

        const disabledDate = (current) => {
            console.log(current)
            return current > moment().startOf('day');
        }

如图:

关于moment的API,可以参考 moment 的具体文档

获取时间值

官网提供的函数:

function onChange(date, dateString) {
  console.log(date, dateString);
  // date 就是原始的日期数值,dateString 就是我们需要的日期格式
}

如果DatePicker组件嵌套在form表单里面,有两种方式获取日期值

第一种方式:

使用官网提供的函数,并在State中设置日期参数

constructor(){
    super()
    this.state={
        date:""
    }
}

onChange = (value,dateString)=>{
    this.setState({
        date:dateString
    })
}

    handleSubmit1 = e => {
        const that = this;
        e.preventDefault();
        this.props.form.validateFieldsAndScroll((err, values) => {
            if (!err) {
                console.log(values.date)
                that.setState({
                    date: that.state.date
                })
                that.getData(1, 10, that.state.date);
            }
        });
    };
                    <Form className="ant-advanced-search-form" onSubmit={this.handleSubmit1}>
                        <div className="search-report">
                            <Form.Item label="日期">
                                {getFieldDecorator('date', {
                                    rules: [
                                        {
                                            required: false,
                                            message: '选择日期',
                                        },
                                    ],
                                })(<DatePicker onChange={this.onChange} format="YYYY-MM-DD" placeholder="选择日期" />)}

                            </Form.Item>
                            <Button type="primary" htmlType="submit">查询</Button>
                        </div>
                    </Form>

这种方式在提交表单的时候,直接从state中获取日期参数值。

第二种方式:

使用moment转换日期

    handleSubmit3 = e => {
        e.preventDefault();
        this.props.form.validateFieldsAndScroll((err, values) => {
            const data = moment(values.date).format('YYYY-MM-DD')
            console.log(data)
        });
    };

赞(0)
未经允许不得转载:飞天狒狒 » antd-DatePicker组件获取时间值,以及相关设置

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址