Angular2 管道

1. 说明

管道用来转换模板显示的内容,应用程序中经常出现获取数据,转换数据,显示数据的逻辑。管道就是用来在转换数据阶段起作用的。主要存在两种类型的管道,pure pipe和impure pipe

2. Pure Pipe

Pure Pipe,stateless,关注于纯粹对象的变更,检测到输入值发生了 纯变更 时才会执行 纯管道 。 纯变更 是指对原始类型值 (String 、Number 、 Boolean 、 Symbol) 的更改, 或者对对象引用 (Date 、 Array 、 Function 、 Object) 的更改。针对复杂对象内部元素的变更不会影响到纯粹管道的执行。常见的内置管道


名称


用法


说明


CurrencyPipe


expression |
currency[:currencyCode[:symbolDisplay[:digitInfo]]]


将数据转化为指定格式的金额格式输出


DatePipe


expression |
date[:format]


将时间数据转换为指定格式的字符串


DecimalPipe


expression |
number[:digitInfo]


将数据转化为指定格式的数据格式输出


LowerCasePipe


expression | lowercase


将数据转化为小写输出


UpperCasePipe


expression | uppercase


将数据转化为大写输出


JsonPipe


expression | json


将数据转化为json格式输出


SlicePipe


expression |
slice:start[:end]


获取指定位置从start到end的数据

3. Impure Pipe

Impure
Pipe,stateful,Angular 会在每个组件的变更检测周期中执行 非纯管道 。 非纯管道可能会被调用很多次,和每个按键或每次鼠标移动一样频繁。常见的内置非纯管道有


名称


用法


说明


AsyncPipe


object |
async


接受一个 Promise 或 Observable 作为输入,并且自动订阅这个输入,最终返回它们给出的值

4. 如何使用

管道把数据作为输入,然后转换它,给出期望的输出。管道使用包括三个方面:

(1). 表达式语法的写法

(2). 如何参数设置

(3). 多个管道如何同时使用

从下面的例子可以很方便的看出来以上三个方面如何编写,


import {
Component } from ‘@angular/core‘;

@Component({

moduleId: ‘app‘,

selector: ‘app‘,

template: `

<h5>your birthday is {{birthday | date:‘MM/dd/yy‘ | uppercase}}</h5>

`,

})

export class
AppComponent {

birthday: Date = new Date(2012, 10, 10);

}

表达式的写法:在插值表达式中数据的右侧通过 管道操作符( | ) 及 右侧的管道函数 来表示

如何设置参数:在管道函数的后面添加一个冒号 ( : ) 再跟一个参数值,来为管道添加参数

多个管道同时使用:在插值表达式数据后面可以同时采用多个管道操作符( | ) 及 右侧的管道函数来表示多个管道,执行顺位为从左到右依次执行。

5. 自定义管道

我们来编写一个自定义管道,管道的含义是截取指定长度的字符串。

5.1 模块

首先我们引入对应的模块及函数Pipe


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

5.2 注解

从@angular/core中导入Pipe及PipeTransform函数后,可以使用@ Pipe ()来标示组件类为一个Pipe,@标示注解的一种标识,用来普通类附加对应的元数据信息。

5.3 元数据

@Pipe将元数据的信息附加到类上,我们来了解一下常用的元数据信息都有哪些:


@Directive({

name: ‘sub‘,

pure: false

})

name:管道的名称,表示在使用管道所采用的名称,例如 date等,

pure:布尔值,纯管道或者非纯管道

5.4 管道类

管道类包含实现数据转化的主要逻辑,管道类必须实现PipeTransform的transform的方法,在数据转化过程中会自动调用这个方法,并将结果返回。我们实现截取的管道类代码如下


export class SubPipe implements PipeTransform {

transform(value: string, length: number): string {

return value.substring(0, length);

}

}

最后实现的代码如下:


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

@Pipe({

name:
‘sub‘,

pure:
false

})

export class SubPipe implements PipeTransform {

transform(value: string, length: number): string {

return value.substring(0, length);

}

}

时间: 2024-10-13 12:42:01

Angular2 管道的相关文章

Angular2入坑指南——管道(搜索功能)

想必大家做项目都会遇到搜索功能吧,通常都是搜索本地数据,如果通过http去请求后台再回显的话,那响应速度简直叫人抓狂,所以大多数都是先存到本地然后进行搜索回显.Angular1的方法很简单,只需要在input标签加入ng-model,然后再在想要显示数据的标签加上| filter就好了,然而,Angular2移除了filter和orderBy,他们的理由是:感觉filter和orderBy响应很慢.我想问:什么是快?怎么快?达到多少KB/s算快?这就要求我们自己写方法来实现了,但是文档提供的仅仅

angular2自学笔记(二)---八大主要构造块

angular的思想:总是把数据访问工作委托给一个支持性服务类. Angular 应用的:用 Angular 扩展语法编写 HTML 模板, 用组件类管理这些模板,用服务添加应用逻辑, 用模块打包发布组件与服务. 我们通过引导根模块来启动该应用. Angular 在浏览器中接管.展现应用的内容,并根据我们提供的操作指令响应用户的交互. angular2的八大主要构造块:模块 (module)组件 (component)模板 (template)元数据 (metadata)数据绑定 (data b

angular2自学笔记---官网项目(一)

1.单向数据绑定的'插值表达式' angular中最典型的数据显示方式:把HTML模板(template)的控件绑定到angular组件的属性(component相当于一个构造函数,下面例子中的这个构造函数有name.title.和hero三个属性)简单来说就是把组件的属性名放到显示曾{{属性名}}中,angular负责喷到页面中:angular从组件中提取属性插入浏览器,然后angular会自动监听这些属性值的变化,一旦属性值发生变化,angular会自动刷新显示,这里的刷新,严格意义上指的是

angular之自定义管道

1,装了angular2 的 cli之后,cmd中命令建立个管道文件 ng g p <name>; 如建一个在pipe文件中建一个add.pipe.ts文件 可以这么么写 ng g p pipe/add; 2,  add.pipe.ts内容如下: //原始内容import { Pipe, PipeTransform } from '@angular/core'; @Pipe({ name: 'add' }) export class AddPipe implements PipeTransfo

1.搭建Angular2项目

简述:搭建angular2的开发环境,网上已经有许多教程,不过都是window系统下的教程,我本人使用的是linux系统,搭建环境的过程也稍微比前者麻烦了一点. 1. pakeage.json配置文件:是用来声明项目中使用的模块,在部署环境时,只要在pakeage所在的目录执行npm install命令就可以安装所有需要的模块了. 新建一个文件夹作为项目的根目录,整个项目的文件都存放在这个文件夹下面.在根目录下创建一个package.json的配置文件,该文件描述了npm包的所有相关信息, 包括

Angular2 NgModule

1. 说明 典型的模块是一个内聚的代码块,用来实现某种单一的功能.Angular2应用程序本质上是有一系列模块组成的,而且Angular 本身就是一组模块库.模块主要是导出一些东西——类,函数,值,供其它模块导入,然后使用这个类,函数或者值.Angular2 应用是模块化的,并且 Angular2 有自己的模块系统,它被称为 Angular2 模块 或 NgModules. NgModules是带有 @NgModule 装饰器函数的 类 . @NgModule 接收一个元数据对象,该对象告诉 A

(三) Angular2项目框架搭建心得

前言: 在哪看到过angular程序员被React程序员鄙视,略显尴尬,确实Angular挺值得被调侃的,在1.*版本存在的几个性能问题,性能优化的"潜规则"贼多,以及从1.*到2.*版本的面目全非,不过宽容点来看这个强大的框架,升级到ng2肯定是一件好事情,虽然截至目前ng2还存在或多或少需要完善的地方,但是ng2做到了留下并强化ng1好的部分,移除或改善其不好的部分,并且基于许多较新Web技术来开发,不去看从ng1迁移到ng2的门槛和工作量的话,ng2的编程体验是很酷炫的. 目前n

Angular2笔记

在Angular2中一个Module指的是使用@NgModule修饰的class.@NgModule利用一个元数据对象来告诉Angular如何去编译和运行代码.一个模块内部可以包含组件.指令.管道,并且可以将它们的访问权限声明为公有,以使外部模块的组件可以访问和使用到它们. 模块是用来组织应用的,通过模块机制外部类库可以很方便的扩展应用,Rc5之后,Angular2将许多常用功能都分配到一个个的模块中,如:FormModule.HttpModule.RouterModule. NgModule的

Angular2中对ASP.NET MVC跨域访问

应用场景 项目开发决定使用angular2进行前后端分离开发,由我负责后端服务的开发,起初选择的是web api进行开发.对跨域访问通过API中间件+过滤器对跨域访问进行支持.开发一段后,通知需要移植到MVC4项目中一同发布angular2并且放弃API,但前期开发仍然需要分离开发. 遇到的问题 想继续使用中间件和过滤器的方式对MVC中的Action进行操作和限制,但经过尝试后发现行不通.主要问题有几下几点. API的处理管道和MVC的处理管道是两个完全不同的东西,所以原来用于API中的编码和方