我正在使用matDatePicker
这种方式:
<mat-form-field class="col">
<input #pickerDal matInput [matDatepicker]="pickerDal" placeholder="Dal"
(dateChange)="fromDate('change', $event)" formControlName="formDataDal">
<mat-datepicker-toggle matSuffix [for]="pickerDal"></mat-datepicker-toggle>
<mat-datepicker #pickerDal></mat-datepicker>
</mat-form-field>
在我的 .ts 中,我声明:
formDataDal: new FormControl()
在我决定在日期选择器中添加默认显示值之前,它一直正常工作。我所做的是[(ngModel)]="dal_default"
在input
标签内添加,并在 .ts 文件中进行初始化dal_default
:
this.dal_default = new Date();
现在,如果我尝试使用 formControlName 或此dal_default
变量打印 Date 的值,我会得到一个奇怪的格式字符串。特别是,如果我打印显示的默认日期,它会正确打印为日期,但是如果我更改日期,我会得到一个字符串(我相信它代表毫秒?)。例如,以下是我从日期 12/12/2018 得到的:
1543618800000
我所做的唯一另一件事是将内部的日期格式更改为app.module.ts
DD/MM/YYYY 格式的日期:
import { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material';
import { MomentDateModule, MomentDateAdapter } from '@angular/material-moment-adapter';
export const MY_FORMATS = {
parse: {
dateInput: 'DD/MM/YYYY',
},
display: {
dateInput: 'DD/MM/YYYY',
monthYearLabel: 'MM YYYY',
dateA11yLabel: 'DD/MM/YYYY',
monthYearA11yLabel: 'MM YYYY',
},
};
和内部提供者:
{ provide: MAT_DATE_LOCALE, useValue: 'it' },
{ provide: DateAdapter, useClass: MomentDateAdapter, deps: [MAT_DATE_LOCALE] },
{ provide: MAT_DATE_FORMATS, useValue: MY_FORMATS }
matdatepicker 以我想要的格式正确显示日期。我不相信这是问题所在,但不能 100% 确定。
问题是什么?