[英]How to format date in React material-ui date-picker?
我正在使用 material-ui 日期选择器字段实现 redux-form。 日期在字段中完美设置,但是当我尝试将其发送到日期的后端 API 格式时:
BeginDate_1: Tue Nov 14 2017 15:03:43 GMT+0530 (IST)
我正在尝试将此格式更改为“YYYY-mm-dd”格式,然后再将其发送到后端 API。
我尝试过使用momentjs
进行格式化,但无法得到我想要的结果。
这是我尝试过的:
主页.js
import React, {Component} from 'react';
import {Field, reduxForm} from 'redux-form';
import DatePicker from 'material-ui/DatePicker';
import {connect} from 'react-redux';
import * as moment from 'moment';
class Home extends Component {
renderCalendarField= ({
input,
label,
meta: {touched, error},
children,
...custom
}) => (
<DatePicker
floatingLabelText={label}
errorText={touched && error}
{...input}
value = {input.value !== ''? new Date(input.value) : null}
onChange={(event, value) => input.onChange(value)}
children={children}
{...custom}
formatDate={(date) => moment(date).format('YYYY-MM-DD')}
/>
)
render() {
const startDate = new Date();
const {handleSubmit} = this.props;
return (
<form onSubmit={handleSubmit(this.onSubmit.bind(this))}>
<div>
<Field name="BeginDate_1" component={this.renderCalendarField} label="DEPARTURE" minDate={startDate} />
</div>
<div>
<button type="submit">
Submit
</button>
</div>
</form>
);
}
}
const LogInForm = reduxForm({
form: 'MaterialUiForm', // a unique identifier for this form
validate
})(Home);
export default connect(mapStateTOProps, {getCity})(LogInForm);
控制台输出仍然是:
BeginDate_1:Tue Nov 14 2017 15:03:43 GMT+0530 (IST)
如何以YYYY-mm-dd
格式格式化此日期?
DatePicker
上的formatDate
prop用于format
Display Date
而不是实际值。 您需要做的是,使用moment
格式化onSubmit
函数中的值
onSubmit (values) {
const beginDate = moment(values.BeginDate_1).format('YYYY-MM-DD')
console.log(beginDate);
//other things
}
根据material-ui / DatePicker文档 :
formatDate :function
调用此函数以格式化输入字段中显示的日期,并应返回一个字符串。 默认情况下,如果未提供区域设置和DateTimeFormat,则日期对象将格式化为
ISO 8601 YYYY-MM-DD.
签名:
function(date: object) => any date: Date object to be formatted. returns (any): The formatted date.
直接来自 DatePicker 的文档。 试试这个
<DatePicker
floatingLabelText={label}
errorText={touched && error}
{...input}
value = {input.value !== ''? new Date(input.value) : null}
onChange={(event, value) => input.onChange(value)}
children={children}
{...custom}
inputFormat="MM/dd/yyyy"
/>
inputFormat 通常应该可以解决问题。 你可以按照你想要的方式改变它,它也可以用于 dateTimePicker。
例如,
inputFormat="yyyy/MM/dd"
或任何其他方式
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.