2

我正在研究 Angular7 及其兼容的 ngx-mat-datetime-picker。它按预期工作。

想要自定义格式:

实际: mm/dd/yyyy, hh:mm:ss 预期: yyyy-mm-dd hh:mm:ss

目前我没有找到任何格式化选项。

我在模板中尝试过这样的事情value="{{ mydate | date: 'yyyy-mm-dd hh:mm:ss' }}

但不工作。

4

3 回答 3

6

您需要创建自定义适配器并指定自定义格式

const CUSTOM_DATE_FORMATS: NgxMatDateFormats = {
  parse: {
    dateInput: 'l, LTS'
  },
  display: {
    dateInput: 'YYYY-MM-DD HH:mm:ss',
    monthYearLabel: 'MMM YYYY',
    dateA11yLabel: 'LL',
    monthYearA11yLabel: 'MMMM YYYY',
  }
};

@NgModule({
  providers: [
    {
      provide: NgxMatDateAdapter,
      useClass: CustomNgxDatetimeAdapter,
      deps: [MAT_DATE_LOCALE, NGX_MAT_MOMENT_DATE_ADAPTER_OPTIONS]
    },
    { provide: NGX_MAT_DATE_FORMATS, useValue: CUSTOM_DATE_FORMATS }
  ],
})
export class CustomNgxDateTimeModule { }

请从以下要点中找到 CustomNgxDatetimeAdapter.ts

https://gist.github.com/nandhakumargdr/635af05419793e15f3758656ddd1ef39

在此处输入图像描述

已经测试过了。这是工作!

于 2020-09-24T13:00:21.083 回答
2

您可以在此处找到更多示例https://github.com/h2qutc/angular-material-components/issues/27

于 2021-02-10T16:28:37.507 回答
1

创建一个常量:(插入您喜欢的格式)

export const DATE_TIME_FORMAT = {
  parse: {
    dateInput: 'l, LT',
  },
  display: {
    dateInput: 'l, LT',
    monthYearLabel: 'MM yyyy',
    dateA11yLabel: 'LL',
    monthYearA11yLabel: 'MMMM YYYY',
  }

提供:

{provide: NGX_MAT_DATE_FORMATS, useValue: DATE_TIME_FORMAT}

结果(我的格式删除了秒数):

9/4/2020, 1:11 PM
于 2020-09-04T20:58:51.210 回答