Angular 中 Pipe(管道) 与 Angular 1.x 中的 filter(过滤器)的作用的是一样的。它们都是用来对输入的数据进行处理,如大小写转换、数值和日期格式化等。
内建管道及分类
- String -> String
- UpperCasePipe
- LowerCasePipe
- CasePipe
- Number -> String
- DecimalPipe
- PercentPipe
- CurrencyPipe
- -> String
- JsonPipe
- DatePipe
- Tools
- KeyValuePipe(v6.1.0)
- SlicePipe
- AsyncPipe
- I18nPluralPipe
- I18nSelectPipe
内建管道使用示例
大写转换
<div>
<p ngNonBindable>{{ 'Angular' | uppercase }}</p>
<p>{{ 'Angular' | uppercase }}</p> <!-- Output: ANGULAR -->
</div>小写转换
<div>
<p ngNonBindable>{{ 'Angular' | lowercase }}</p>
<p>{{ 'Angular' | lowercase }}</p> <!-- Output: angular -->
</div>数值格式化
<div>
<p ngNonBindable>{{ 3.14159265 | number: '1.4-4' }}</p>
<p>{{ 3.14159265 | number: '1.4-4' }}</p> <!-- Output: 3.1416 -->
</div>日期格式化
<div>
<p ngNonBindable>{{ today | date: 'shortTime' }}</p>
<p>{{ today | date: 'shortTime' }}</p> <!-- Output: 以当前时间为准,输出格式:10:40 AM -->
</div>对象序列化
<div>
<p ngNonBindable>{{ { name: 'sem er' } | json }}</p>
<p>{{ { name: 'sem er' } | json }}</p> <!-- Output: { "name": "sem er" } -->
</div>对象转换
<!-- : {[key: number]: string} = {2: 'foo', 1: 'bar'}; -->
<div *ngFor="let item of | keyvalue">
{{item.key}}: {{item.value}}
</div>管道参数
管道可以接收任意数量的参数,使用方式是在管道名称后面添加 : 和参数值。如 number: '1.4-4' ,若需要传递多个参数则参数之间用冒号隔开,具体示例如下:
<div>
<p ngNonBindable>{{ 'sem er' | slice:0:3 }}</p>
<p>{{ 'sem er' | slice:0:3 }}</p> <!-- Output: sem -->
</div>管道链
我们可以将多个管道连接在一起,组成管道链对数据进行处理。
<div>
<p ngNonBindable>{{ 'sem er' | slice:0:3 | uppercase }}</p>
<p>{{ 'sem er' | slice:0:3 | uppercase }}</p> <!-- Output: SEM -->
</div>完整示例
import { Component } from '@angular/core';
@Component({
selector: 'my-app',
template: `
<div>
<p ngNonBindable>{{ 'Angular' | uppercase }}</p>
<p>{{ 'Angular' | uppercase }}</p>
</div>
<div>
<p ngNonBindable>{{ 'Angular' | lowercase }}</p>
<p>{{ 'Angular' | lowercase }}</p>
</div>
<div>
<p ngNonBindable>{{ 3.14159265 | number: '1.4-4' }}</p>
<p>{{ 3.14159265 | number: '1.4-4' }}</p>
</div>
<div>
<p ngNonBindable>{{ today | date: 'shortTime' }}</p>
<p>{{ today | date: 'shortTime' }}</p>
</div>
<div>
<p ngNonBindable>{{ { name: 'sem er' } | json }}</p>
<p>{{ { name: 'sem er' } | json }}</p>
</div>
<div>
<p ngNonBindable>{{ 'sem er' | slice:0:3 }}</p>
<p>{{ 'sem er' | slice:0:3 }}</p>
</div>
<div>
<p ngNonBindable>{{ 'sem er' | slice:0:3 | uppercase }}</p>
<p>{{ 'sem er' | slice:0:3 | uppercase }}</p>
</div>
`,
})
export class AppComponent {
today = new Date();
}自定义管道
自定义管道的步骤:
- 使用
@Pipe装饰器定义 Pipe 的 data 信息,如 Pipe 的名称 - 即 name 属性 - 实现
PipeTransform接口中定义的 transform 方法
WelcomePipe 定义
import { Pipe, PipeTransform } from '@angular/core';
@Pipe({ name: 'welcome' })
export class WelcomePipe implements PipeTransform {
transform(value: string): string {
if(!value) return value;
if(typeof value !== 'string') {
throw new Error('Invalid pipe argument for WelcomePipe');
}
return "Welcome to " + value;
}
}WelcomePipe 使用
<div>
<p ngNonBindable>{{ 'sem er' | welcome }}</p>
<p>{{ 'sem er' | welcome }}</p> <!-- Output: Welcome to sem er -->
</div>当 WelcomePipe 的输入参数,即 value 值为非字符串时,如使用 123,则控制台将会抛出以下异常:
EXCEPTION: Error in ./AppComponent class AppComponent caused by: Invalid pipe argument for WelcomePipe
RepeatPipe 定义
import {Pipe, PipeTransform} from '@angular/core';
@Pipe({name: 'repeat'})
export class RepeatPipe implements PipeTransform {
transform(value: any, times: number) {
return value.repeat(times);
}
}RepeatPipe 使用
<div>
<p ngNonBindable>{{ 'lo' | repeat:3 }}</p>
<p>{{ 'lo' | repeat:3 }}</p> <!-- Output: lololo -->
</div>管道分类
- pure 管道:仅当管道输入值变化的时候,才执行转换操作,默认的类型是
pure类型。(备注:输入值变化是指原始数据类型如:string、number、boolean 等的数值或对象的引用值发生变化)。 - impure 管道:在每次变化检测期间都会执行,如鼠标点击或移动都会执行
impure管道。
总结
本文介绍了 Angular 中的常用内建管道的用法和管道的分类,同时也介绍了 pure 和 impure 管道的区别。 此外我们通过两个示例展示了如何自定义管道,最后详细分析了 RepeatPipe 管道的工作原理。建议读者更改 RepeatePipe 的 pure 属性为 false,体验一下 impure 管道。
继续阅读与本文标签相同的文章
上一篇 :
Angular 6.x 表单快速入门
下一篇 :
Angular 6.x 快速入门
-
c++ string的字节对齐
2026-05-21栏目: 教程
-
C++构造函数互调纠正
2026-05-21栏目: 教程
-
Angular ViewChild和ViewChildren
2026-05-21栏目: 教程
-
云服务器使用教程-基于CentOS搭建 FTP 文件服务
2026-05-21栏目: 教程
-
RxJS mergeMap和switchMap
2026-05-21栏目: 教程
