问题描述
以“ YYYY-MM-DD HH:mm:ss”格式返回Moment对象而不是Date值
我尝试了以下操作,但获取了矩对象而不是日期。我搜索了很多,但没有一个给我解决方案。
import * as _moment from 'moment';
import { default as _rollupMoment } from 'moment';
const moment = _rollupMoment || _moment;
export const MY_FORMATS = {
parse: {
dateInput: 'YYYY-MM-DD HH:mm:ss',},display: {
dateInput: 'YYYY-MM-DD HH:mm:ss',monthYearLabel: 'MMM YYYY',dateA11yLabel: 'YYYY-MM-DD HH:mm:ss',monthYeara11yLabel: 'MMMM YYYY',};
我在@Component装饰器中提供了格式
@Component({
providers: [
{
provide: DateAdapter,useClass: MomentDateAdapter,deps: [MAT_DATE_LOCALE,MAT_MOMENT_DATE_ADAPTER_OPTIONS]
},{ provide: MAT_DATE_FORMATS,useValue: MY_FORMATS },]
})
内部类=>
dateOfBirth: new FormControl();
解决方法
在您的应用程序中添加以下代码。
app.module.ts
import { DateAdapter,MAT_DATE_FORMATS,MAT_DATE_LOCALE } from '@angular/material/core';
import { MomentDateModule,MomentDateAdapter } from '@angular/material-moment-adapter';
import { DatePipe } from '@angular/common';
export const DateFormats = {
parse: {
dateInput: 'YYYY-MM-DD HH:mm:ss',},display: {
dateInput: 'YYYY-MM-DD HH:mm:ss',monthYearLabel: 'MMM YYYY',dateA11yLabel: 'YYYY-MM-DD HH:mm:ss',monthYearA11yLabel: 'MMMM YYYY',};
providers: [
{ provide: DateAdapter,useClass: MomentDateAdapter,deps: [MAT_DATE_LOCALE] },{ provide: MAT_DATE_FORMATS,useValue: DateFormats },DatePipe
],
* .components,ts
dateOfBirth: new FormControl();
如果您在项目中正确添加了以上代码,则会以YYYY-MM-DD HH:mm:ss的格式获取所有日期选择器日期值
,尝试此代码。
val response: Response = chain.proceed(chain.request())
return chain.proceed(chain.request())