覆盖 Angular 默认日期管道
Override Angular default date pipe
我需要覆盖默认的 Angular 7 种日期管道格式(medium
、short
、fullDate
等),因为我不想使用两个日期管道(默认一个和一个自定义管道),所以我做了以下内容并且想知道这样做是不是一个好主意:
// extend-date.pipe.ts
import { Pipe, PipeTransform } from '@angular/core';
import { DatePipe } from '@angular/common';
@Pipe({
name: 'date'
})
export class ExtendDatePipe extends DatePipe implements PipeTransform {
constructor() {
super('en-US');
this.customDateFormats = {
medium: '...',
short: '...',
fullDate: '...',
longDate: '...',
mediumDate: '...',
shortDate: '...',
mediumTime: '...',
shortTime: '...'
};
}
transform(value: any, args?: any): any {
switch (args) {
case 'medium':
return super.transform(value, this.customDateFormats.medium);
case 'short':
return super.transform(value, this.customDateFormats.short);
case 'fullDate':
return super.transform(value, this.customDateFormats.fullDate);
case 'longDate':
return super.transform(value, this.customDateFormats.longDate);
case 'mediumDate':
return super.transform(value, this.customDateFormats.mediumDate);
case 'shortDate':
return super.transform(value, this.customDateFormats.shortDate);
case 'mediumTime':
return super.transform(value, this.customDateFormats.mediumTime);
case 'shortTime':
return super.transform(value, this.customDateFormats.shortTime);
default:
return super.transform(value, args);
}
}
}
// app.component.html
{{ someDate | date: 'medium' }} // The custom format will be displayed
如果我使用类似 {{ someDate | date: 'MM/dd/yyyy' }}
的东西,它也能正常工作。
基本上,我想知道是否存在无法正常工作的情况,或者可能有更好的方法来实现此目的,但实现方式不同?
您错过了日期管道中的某些功能。它除了 format
,还有 timezone
和 locale
作为 parameters。
可以覆盖默认管道,其中添加的管道 'last' 将获得优先权。要在整个应用程序中覆盖 angular 管道,只需将自定义管道添加到根 AppModule 的声明数组中即可:
@NgModule({
//...
declarations: [
//...
ExtendDatePipe
]
})
export class AppModule {}
注意:曾经有一个 PLATFORM_PIPES
常量来覆盖 global/default 管道,但是现在 removed
为了可读性以及保持本地化和国际化的可能性,我只是将其更改为这样。:
@Pipe({
name: 'date'
})
export class ExtendDatePipe extends DatePipe implements PipeTransform {
readonly customFormats = {
medium: 'xxx',
short: 'xxx',
// ...
};
constructor(@Inject(LOCALE_ID) locale: string) {
super(locale);
}
transform(value: any, format = 'mediumDate', timezone?: string, locale?: string): string {
format = this.customFormats[format] || format;
return super.transform(value, format, timezone, locale);
}
}
我需要覆盖默认的 Angular 7 种日期管道格式(medium
、short
、fullDate
等),因为我不想使用两个日期管道(默认一个和一个自定义管道),所以我做了以下内容并且想知道这样做是不是一个好主意:
// extend-date.pipe.ts
import { Pipe, PipeTransform } from '@angular/core';
import { DatePipe } from '@angular/common';
@Pipe({
name: 'date'
})
export class ExtendDatePipe extends DatePipe implements PipeTransform {
constructor() {
super('en-US');
this.customDateFormats = {
medium: '...',
short: '...',
fullDate: '...',
longDate: '...',
mediumDate: '...',
shortDate: '...',
mediumTime: '...',
shortTime: '...'
};
}
transform(value: any, args?: any): any {
switch (args) {
case 'medium':
return super.transform(value, this.customDateFormats.medium);
case 'short':
return super.transform(value, this.customDateFormats.short);
case 'fullDate':
return super.transform(value, this.customDateFormats.fullDate);
case 'longDate':
return super.transform(value, this.customDateFormats.longDate);
case 'mediumDate':
return super.transform(value, this.customDateFormats.mediumDate);
case 'shortDate':
return super.transform(value, this.customDateFormats.shortDate);
case 'mediumTime':
return super.transform(value, this.customDateFormats.mediumTime);
case 'shortTime':
return super.transform(value, this.customDateFormats.shortTime);
default:
return super.transform(value, args);
}
}
}
// app.component.html
{{ someDate | date: 'medium' }} // The custom format will be displayed
如果我使用类似 {{ someDate | date: 'MM/dd/yyyy' }}
的东西,它也能正常工作。
基本上,我想知道是否存在无法正常工作的情况,或者可能有更好的方法来实现此目的,但实现方式不同?
您错过了日期管道中的某些功能。它除了 format
,还有 timezone
和 locale
作为 parameters。
可以覆盖默认管道,其中添加的管道 'last' 将获得优先权。要在整个应用程序中覆盖 angular 管道,只需将自定义管道添加到根 AppModule 的声明数组中即可:
@NgModule({
//...
declarations: [
//...
ExtendDatePipe
]
})
export class AppModule {}
注意:曾经有一个 PLATFORM_PIPES
常量来覆盖 global/default 管道,但是现在 removed
为了可读性以及保持本地化和国际化的可能性,我只是将其更改为这样。:
@Pipe({
name: 'date'
})
export class ExtendDatePipe extends DatePipe implements PipeTransform {
readonly customFormats = {
medium: 'xxx',
short: 'xxx',
// ...
};
constructor(@Inject(LOCALE_ID) locale: string) {
super(locale);
}
transform(value: any, format = 'mediumDate', timezone?: string, locale?: string): string {
format = this.customFormats[format] || format;
return super.transform(value, format, timezone, locale);
}
}