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-DD或YYYY-MM-DDTHH:mm格式。
我是Angular的新手
提前致谢
Nat*_*ram 16
没必要用MomentDateAdapter!
这是我使用最少代码并使用MAT_NATIVE_DATE_FORMATS.
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)
@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 中添加上面的代码。它非常适合我。
您需要提供一个包含您要使用的格式的对象。该对象应类似于:
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)
| 归档时间: |
|
| 查看次数: |
9660 次 |
| 最近记录: |