欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Angular2的管道Pipe的使用方法

 更新時(shí)間:2017年11月07日 09:59:52   作者:angular  
本篇文章主要介紹了Angular 2的管道Pipe的使用方法,詳細(xì)的介紹了管道的定義和使用方法,具有一定的參考價(jià)值,有興趣的可以了解一下

管道Pipe可以將數(shù)據(jù)作為輸入,然后按照規(guī)則將其轉(zhuǎn)換并輸出。在Angular2中有許多內(nèi)置的Pipe,比如DatePipe、UpperCasePipe和CurrencyPipe等。在這里我們主要介紹如何自定義Pipe。

1. 管道定義

Pipe的定義如下代碼所示:

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

/*users: Array<any> = [
  { name: '1', id: 1 },
  { name: '2', id: 2 },
  { name: '3', id: 3 },
  { name: '4', id: 4 },
  { name: '5', id: 5 },
  { name: '6', id: 6 }
];*/

@Pipe({ name: 'filterUser' })
export class FilterUserPipe implements PipeTransform {
  transform(allUsers: Array<any>, ...args: any[]): any {
    return allUsers.filter(user => user.id > 3);
  }
}

如代碼所示,

  1. 需要使用@Pipe來裝飾類
  2. 實(shí)現(xiàn)PipeTransform的transform方法,該方法接受一個(gè)輸入值和一些可選參數(shù)
  3. 在@Pipe裝飾器中指定管道的名字,這個(gè)名字就可以在模板中使用。

注意:當(dāng)定義完成后,不要忘記在Module的declarations數(shù)組中包含這個(gè)管道。

2. 管道使用

user.template.html實(shí)現(xiàn)如下所示:

<div>
  <ul>
    <li *ngFor="let user of (users | filterUser)">
      {{user.name}}
    </li>
  </ul>
</div>
<button (click)="addUser()"> add new user</button>

user.component.ts實(shí)現(xiàn)如下所示:

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

@Component({
  templateUrl: './user.template.html',
})

export class EnvAppComponent {
  id = 7;
  users: Array<any> = [
    { name: '1', id: 1 },
    { name: '2', id: 2 },
    { name: '3', id: 3 },
    { name: '4', id: 4 },
    { name: '5', id: 5 },
    { name: '6', id: 6 }
  ];

  addUser() {
    this.users.push({ name: this.id++, id: this.id++ })
  }
}

在user.component.ts中初始了數(shù)據(jù)users和定義一個(gè)添加user的方法,在user.template.html中使用自定義管道filterUser。

當(dāng)啟動(dòng)應(yīng)用時(shí),可以發(fā)現(xiàn)只有id大于3的user被顯示出來了。可是,當(dāng)你點(diǎn)擊按鈕添加用戶時(shí),發(fā)現(xiàn)并沒有什么反應(yīng),數(shù)據(jù)并沒有改變。這是為什么呢?

3. 數(shù)據(jù)變更檢測(cè)

在Angular2中管道分為兩種:純管道和非純管道。默認(rèn)情況下管道都是純管道。

純管道就是在Angular檢測(cè)到它的輸入值發(fā)生了純變更時(shí)才會(huì)執(zhí)行管道。純變更也就是說原始數(shù)據(jù)類型(如String、Number和Boolean等)或者對(duì)象的引用發(fā)生變化。該管道會(huì)忽略對(duì)象內(nèi)部的變化,在示例中,數(shù)組的引用沒有發(fā)生改變,改變的只是數(shù)組內(nèi)部的數(shù)據(jù),所以當(dāng)我們添加數(shù)據(jù)時(shí)并沒有立即響應(yīng)在頁(yè)面上。

非純管道會(huì)在組件的變更檢測(cè)周期中執(zhí)行,而且會(huì)對(duì)對(duì)象的內(nèi)部數(shù)據(jù)進(jìn)行檢測(cè)。

在我們的示例中將管道變更為非純管道是非常賤簡(jiǎn)單的,只要在管道元數(shù)據(jù)中將添加pure標(biāo)志為false即可。

代碼如下所示:

@Pipe({ name: 'filterUser', pure: false })
export class FilterUserPipe implements PipeTransform {
  transform(allUsers: Array<any>, ...args: any[]): any {
    return allUsers.filter(user => user.id > 3);
  }
}

這樣每當(dāng)我們添加新用戶時(shí),數(shù)據(jù)就會(huì)馬上響應(yīng)在頁(yè)面上了。

在根模塊聲明的pipe在頁(yè)面中引用有效,而在頁(yè)面中引用的component中的模板則無(wú)效,這也是令我困惑的地方...

尋求了一些解決方案,大多是要注意得在根模塊中聲明,于是我做了個(gè)嘗試,將組件也寫成一個(gè)功能模塊,并在組件功能模塊中申明pipe,結(jié)果很欣喜,組件中的pipe生效了。

具體操作方法:

只需新建組件功能模塊,并在改模塊中申明pipe,myComponent.module.ts

import { NgModule } from '@angular/core';
import { IonicPageModule } from 'ionic-angular';
import { myComponent } from 'myComponent.ts';
import { HelloPipe } from "hello.pipe.ts";

@NgModule({
 declarations: [
  myComponent,
  HelloPipe
 ],

 imports: [
  IonicPageModule.forChild(myComponent)
 ],

 exports: [
  myComponent
 ]
})

export class MyComponent {}

大功告成,組件的模板引用pipe得以生效.

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 在AngularJs中設(shè)置請(qǐng)求頭信息(headers)的方法及不同方法的比較

    在AngularJs中設(shè)置請(qǐng)求頭信息(headers)的方法及不同方法的比較

    在AngularJs中有三種方式可以設(shè)置請(qǐng)求頭信息,文中對(duì)每種方法給大家介紹的非常詳細(xì),選擇那種方式可以根據(jù)自己的需求,感興趣的朋友跟隨腳本之家小編一起看看吧
    2018-09-09
  • AngularJS在IE8的不支持的解決方法

    AngularJS在IE8的不支持的解決方法

    AngularJS在IE8的不支持怎么辦?下面小編就為大家?guī)硪黄狝ngularJS在IE8的不支持的解決方法。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-05-05
  • 使用Angular CLI進(jìn)行Build(構(gòu)建)和Serve詳解

    使用Angular CLI進(jìn)行Build(構(gòu)建)和Serve詳解

    這篇文章主要介紹了使用Angular CLI進(jìn)行Build(構(gòu)建)和Serve詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-03-03
  • Angular項(xiàng)目從新建、打包到nginx部署全過程記錄

    Angular項(xiàng)目從新建、打包到nginx部署全過程記錄

    一直比較喜歡angular,正巧最近有個(gè)項(xiàng)目用到了,所以想和大家來分享下,下面這篇文章主要給大家介紹了關(guān)于Angular項(xiàng)目從新建、打包到nginx部署的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下。
    2017-12-12
  • Angularjs中的ui-bootstrap的使用教程

    Angularjs中的ui-bootstrap的使用教程

    這篇文章主要介紹了Angularjs中的ui-bootstrap的使用教程,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-02-02
  • ng-repeat指令在迭代對(duì)象時(shí)的去重方法

    ng-repeat指令在迭代對(duì)象時(shí)的去重方法

    今天小編就為大家分享一篇ng-repeat指令在迭代對(duì)象時(shí)的去重方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • Angular 2使用路由自定義彈出組件toast操作示例

    Angular 2使用路由自定義彈出組件toast操作示例

    這篇文章主要介紹了Angular 2使用路由自定義彈出組件toast操作,結(jié)合實(shí)例形式分析了Angular2使用路由操作彈出組件toast相關(guān)定義與使用技巧,需要的朋友可以參考下
    2019-05-05
  • angular2中router路由跳轉(zhuǎn)navigate的使用與刷新頁(yè)面問題詳解

    angular2中router路由跳轉(zhuǎn)navigate的使用與刷新頁(yè)面問題詳解

    這篇文章主要給大家介紹了angular2中router路由跳轉(zhuǎn)navigate的使用與刷新頁(yè)面問題的相關(guān)資料,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。
    2017-05-05
  • AngularJS中table表格基本操作示例

    AngularJS中table表格基本操作示例

    這篇文章主要介紹了AngularJS中table表格基本操作,涉及AngularJS針對(duì)table表格元素與屬性的相關(guān)動(dòng)態(tài)操作技巧,需要的朋友可以參考下
    2017-10-10
  • angular 未登錄狀態(tài)攔截路由跳轉(zhuǎn)的方法

    angular 未登錄狀態(tài)攔截路由跳轉(zhuǎn)的方法

    今天小編就為大家分享一篇angular 未登錄狀態(tài)攔截路由跳轉(zhuǎn)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10

最新評(píng)論