如何更改角度材质的日期选择器格式

mmo*_*ies 5 date typescript angular-material2 angular

这是我在使用角形材质datepicker时获得的日期格式。Wed Nov 21 2018 00:00:00 GMT+0530 (India Standard Time)

但我需要在日期(YYYY-MM-DD)(YYYY-MM-DDTHH:mm)这种格式。

这是我用来从角形材料形式捕获数据的模型类

export class FlightSchedule {

    constructor(
        public destination: string,
        public origin: string,
        public date: string,
        public limit: string
    ) {}

}
Run Code Online (Sandbox Code Playgroud)

请帮助我,我无法转换日期YYYY-MM-DDYYYY-MM-DDTHH:mm格式。

我是Angular的新手

提前致谢

Nat*_*ram 16

没必要用MomentDateAdapter

这是我使用最少代码使用MAT_NATIVE_DATE_FORMATS.

  1. 声明你自己的日期格式
import { MatDateFormats, MAT_NATIVE_DATE_FORMATS } from '@angular/material';

export const GRI_DATE_FORMATS: MatDateFormats = {
  ...MAT_NATIVE_DATE_FORMATS,
  display: {
    ...MAT_NATIVE_DATE_FORMATS.display,
    dateInput: {
      year: 'numeric',
      month: 'short',
      day: 'numeric',
    } as Intl.DateTimeFormatOptions,
  }
};
Run Code Online (Sandbox Code Playgroud)
  1. 使用它们
@Component({
  selector: 'app-vacation-wizard',
  templateUrl: './vacation-wizard.component.html',
  styleUrls: ['./vacation-wizard.component.scss'],
  providers: [
    { provide: MAT_DATE_FORMATS, useValue: GRI_DATE_FORMATS },
  ]
})
Run Code Online (Sandbox Code Playgroud)

不要忘记设置适当的语言!

constructor(private readonly adapter: DateAdapter<Date>) {}
this.adapter.setLocale(this.translate.currentLang);
Run Code Online (Sandbox Code Playgroud)

就这样!


小智 11

import { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material';
import { MomentDateModule, MomentDateAdapter } from '@angular/material-moment-adapter';

 export const DateFormats = {
            parse: {
                dateInput: ['YYYY-MM-DD']
            },
            display: {
                dateInput: 'YYYY-MM-DD',
                monthYearLabel: 'MMM YYYY',
                dateA11yLabel: 'LL',
                monthYearA11yLabel: 'MMMM YYYY',
            },
        };

    providers: [

        { provide: DateAdapter, useClass: MomentDateAdapter, deps: [MAT_DATE_LOCALE] },
          { provide: MAT_DATE_FORMATS, useValue: DateFormats }

      ],
Run Code Online (Sandbox Code Playgroud)

在你的 app.module 中添加上面的代码。它非常适合我。

  • @MSM 在运行时有什么方法可以做到这一点 (3认同)

use*_*994 7

您需要提供一个包含您要使用的格式的对象。该对象应类似于:

export const MY_FORMATS = {
  parse: {
    dateInput: 'LL',
  },
  display: {
    dateInput: 'YYYY-MM-DD',
    monthYearLabel: 'YYYY',
    dateA11yLabel: 'LL',
    monthYearA11yLabel: 'YYYY',
  },
};
Run Code Online (Sandbox Code Playgroud)

然后,您需要将其添加到您的provider数组中,如下所示:

  import { MAT_DATE_FORMATS } from '@angular/material';
  import { MomentDateAdapter } from '@angular/material-moment-adapter';

  //...

  providers: [
    {provide: DateAdapter, useClass: MomentDateAdapter, deps: [MAT_DATE_LOCALE]},
    {provide: MAT_DATE_FORMATS, useValue: MY_FORMATS},
  ],
Run Code Online (Sandbox Code Playgroud)

这是一个StackBlitz演示以展示其工作原理