深入了解Angular中的PIPE(管道)


本文摘自PHP中文网,作者青灯夜游,侵删。

在angular中,pipe(管道)可以用来对输入的数据进行处理,且不同的管道具有不同的作用。那么具体要怎么使用pipe(管道)?下面本篇文章就来带大家深入研究一下Angular中的PIPE(管道),看看它的使用方法。

PIPE,翻译为管道。Angular 管道是编写可以在HTML组件中声明的显示值转换的方法。Angular 管道之前在 AngularJS 中被称为过滤器,从 Angular 2开始就被称为管道。管道将数据作为输入并将其转换为所需的输出。

Angular Pipes 将整数、字符串、数组和日期作为输入,用| 分隔,然后根据需要转换成格式,并在浏览器中显示出来。在插值表达式中,可以定义管道并根据情况使用它,在 Angular 应用程序中可以使用许多类型的管道。

【相关教程推荐:《angular教程》】

内建管道

  • String -> String

    • UpperCasePipe

    • LowerCasePipe

    • TitleCasePipe

  • Number -> String

    • DecimalPipe

    • PercentPipe

    • CurrencyPipe

  • Object -> String

    • JsonPipe

    • DatePipe

  • Tools

    • SlicePipe

    • AsyncPipe

    • I18nPluralPipe

    • I18nSelectPipe

使用方法

大写转换

1

2

3

4

<div>

  <p ngNonBindable>{{ 'Angular' | uppercase }}</p>

  <p>{{ 'Angular' | uppercase }}</p> <!-- Output: ANGULAR -->

</div>

日期格式化

1

2

3

4

<div>

  <p ngNonBindable>{{ today | date: 'shortTime' }}</p>

  <p>{{ today | date: 'shortTime' }}</p> <!-- Output: 以当前时间为准,输出格式:10:40 AM -->

</div>

数值格式化

1

2

3

4

<div>

  <p ngNonBindable>{{ 3.14159265 | number: '1.4-4' }}</p>

  <p>{{ 3.14159265 | number: '1.4-4' }}</p> <!-- Output: 3.1416 -->

</div>

JavaScript 对象序列化

1

2

3

4

<div>

  <p ngNonBindable>{{ { name: 'semlinker' } | json }}</p>

  <p>{{ { name: 'semlinker' } | json }}</p> <!-- Output: { "name": "semlinker" } -->

</div>

管道参数

管道可以接收任意数量的参数,使用方式是在管道名称后面添加:和参数值。如number: '1.4-4',若需要传递多个参数则参数之间用冒号隔开,具体示例如下:

1

2

3

4

<div>

  <p ngNonBindable>{{ 'semlinker' | slice:0:3 }}</p>

  <p>{{ 'semlinker' | slice:0:3 }}</p> <!-- Output: sem -->

</div>

管道链

可以将多个管道连接在一起,组成管道链对数据进行处理。

1

2

3

4

<div>

  <p ngNonBindable>{{ 'semlinker' | slice:0:3 | uppercase }}</p>

  <p>{{ 'semlinker' | slice:0:3 | uppercase }}</p>

</div>

自定义管道

下面以过往项目中使用的管道为示例,讲解自定义管道步骤:

  • 使用 @Pipe 装饰器定义 Pipemetadata 信息,如 Pipe 的名称 - 即 name 属性

  • 实现 PipeTransform 接口中定义的 transform 方法

定义

1

2

3

4

5

6

7

8

9

10

11

12

13

14

import { Pipe, PipeTransform } from "@angular/core";

 

@Pipe({ name: "formatError" })

export class FormatErrorPipe implements PipeTransform {

    constructor() {}

 

    transform(value: any, module: string) {

        if (value.code) {

            return value.desc;

        } else {

            return value.message;

        }

    }

}

使用

1

2

3

4

5

<div *ngIf="errorMessage">

    <div class="message-box error mb-16" [@animate]="{value:'*',params:{opacity:'0',duration:'200ms'}}">

        {{errorMessage.error | formatError:"auth"}}

    </div>

</div>

完~

更多编程相关知识,请访问:编程教学!!

以上就是深入了解Angular中的PIPE(管道)的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

AngularAngularjs间有什么关系

深入了解Angular组件中的生命周期钩子

Angular中什么是ivy编译?如何开启ivy编译?

浅谈Angular中http请求模块的用法

一文快速了解Angular中的ngrx/store框架

了解Angularjs中的“模块”

Angular cli是什么以及如何安装

聊聊Angular项目中将 .css 文件修改为 .scss 文件的方法

浅谈Angular中的模块(ngmodule),延迟加载模块

详解Angular中的material安装与使用

更多相关阅读请进入《Angular》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...