亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Angular2內(nèi)置指令NgFor和NgIf詳解

 更新時(shí)間:2016年08月03日 11:39:59   作者:此刻最好  
Directive的概念在Angular 1.x就存在了,我對(duì)它的認(rèn)識(shí)比較模糊,所以直接通過一些例子來說明。Angular提供的內(nèi)置執(zhí)行有很多,這次使用兩個(gè):ngFor、ngIf。

在這一章節(jié)中,我們來學(xué)習(xí)如何使用Angular2來展示數(shù)據(jù),以及如何使用它的內(nèi)置指令NgForNgIf

首先要確保你有一個(gè)可以運(yùn)行起來的Angular2的樣例程序,最好就是我們上一章節(jié)中完成的那個(gè)QuickStart小項(xiàng)目或者你自己根據(jù)官網(wǎng)上面的步驟完成的QuickStart小項(xiàng)目,因?yàn)槲覀兊闹v解都是在那個(gè)基礎(chǔ)上來進(jìn)行的;然后讓我們開始下面的快樂旅程吧.

因?yàn)槲覀兊倪@一系列的文章都是使用的TypeScript所以在看下面的內(nèi)容之前你最好可以看一下TypeScript或者ES6的類,它們的網(wǎng)址分別是TypeScript,ES6;如果以前你學(xué)過Java或者C++這種類似的面向?qū)ο蟮恼Z言的話,那么學(xué)習(xí)這里的類就很輕松了;這里面的類基本上和那些語言中的類是相似的.

上一節(jié)中我們?cè)?code>app.component.ts中導(dǎo)出了一個(gè)空的類,那么下面我們就要開始填充它,讓它變得豐滿起來.首先我們給這個(gè)AppComponent類(組件)添加三個(gè)屬性,分別是name,age,fruit;就像下面這樣:

export class AppComponent {
  username = 'dreamapple';
  age = 22;
  fruit = 'apple'
}

上面的寫法其實(shí)只是一種簡(jiǎn)寫的形式,實(shí)際上完整的寫法應(yīng)該是這樣的:

export class AppComponent {
  //username = 'dreamapple';
  //age = 22;
  //fruit = 'apple'
  username: string;
  age: number;
  fruit: string;

  constructor() {
    this.username = 'dreamapple';
    this.age = 22;
    this.fruit = 'apple';
  }
}

然后我們要修改我們的模板了,因?yàn)槲覀冊(cè)谀0逯幸褂幂^多的HTML,所以我們要使用反引號(hào)來包裹住我們的HTML片段;我們的裝飾器函數(shù)如下所示:

@Component({
  selector: 'my-app',
  template:`
    <p>My name is: {{username}}</p>
    <p>My age is: {{age}}</p>
    <p>My favorite fruit is: {{fruit}}</p>
  `
})

當(dāng)然我們也可以使用裝飾器函數(shù)中元數(shù)據(jù)對(duì)象的templateUrl配置選項(xiàng),如下所示:

@Component({
  selector: 'my-app',
  //template:`
  //  <p>My name is: {{username}}</p>
  //  <p>My age is: {{age}}</p>
  //  <p>My favorite fruit is: {{fruit}}</p>
  //`,
  templateUrl: 'app/templates/app-template.html'
})

其中app/templates/app-template.html表示的是程序的根目錄app(而不是angular2-travel)下的templates文件夾下的app-template.html文件,然后將我們之前寫的HTML片段復(fù)制過去就好了.

從上面的過程中,我們可以看到Angular2顯示數(shù)據(jù)依然使用的是Angular1慣用的雙大括號(hào);它作為一個(gè)插值符號(hào),在這個(gè)插值符號(hào)出現(xiàn)的地方就是我們要顯示的數(shù)據(jù)的地方.接下來我們要學(xué)習(xí)使用NgFor這個(gè)內(nèi)置指令了,熟悉Angular1的同學(xué)應(yīng)該很容易就上手這個(gè)指令,因?yàn)镹gFor和ng-repeat基本是一樣的;它用來循環(huán)一個(gè)可迭代的對(duì)象,一般情況下會(huì)是一個(gè)數(shù)組.

接下來我們給AppComponent再添加一個(gè)屬性fruitsList,如下所示:

export class AppComponent {
  username = 'dreamapple';
  age = 22;
  fruitsList = ['apple', 'orange', 'pear', 'banana'];
  fruit = this.fruitsList[0]; // 這里要使用 this.fruitsList[0]
}

我們需要注意的地方是那個(gè)有注釋的地方,我們必須使用this.fruitsList來指代上面我們已經(jīng)定義好的屬性,如果使用fruitsList的話,Angular就不知道它表示是什么.
接下來我們要循環(huán)這個(gè)水果數(shù)組了,看看如何在模板中表示吧.

@Component({
  selector: 'my-app',
  template:`
    <p>My name is: {{username}}</p>
    <p>My age is: {{age}}</p>
    <ul>
      <li *ngFor="let fruit of fruitsList">{{fruit}}</li>
    </ul>
    <p>My favorite fruit is: {{fruit}}</p>
  `
})

上面的代碼中有幾個(gè)地方是需要注意的地方,首先我們使用了*ngFor而不是ngFor,這里的*是不能夠去掉的;如果去掉的話那么我們的程序不會(huì)報(bào)錯(cuò),但是我們只循環(huán)出來了數(shù)組的第一項(xiàng).關(guān)于為何要加*,你可以詳細(xì)的看看這里模板語法;當(dāng)然我們可以在*ngFor表達(dá)式的后面寫一些能夠幫助我們展示每一項(xiàng)索引的操作,可以像下面這樣:

<li *ngFor="let fruit of fruitsList; let i = index;">{{i}}-{{fruit}}</li>
上面的模板代碼有一些需要注意的地方,首先要知道*ngFor后面跟的是表達(dá)式,所以我們可以寫一些簡(jiǎn)單的表達(dá)式,幫助我們更好地進(jìn)行循環(huán);還有我們使用了let關(guān)鍵詞,增加了塊級(jí)作用域,使我們的這些變量都限定在*ngFor這個(gè)循環(huán)塊中.好啦,如果你想更多地了解*ngFor,你可以看一下官方關(guān)于NgFor的API.

接下來要介紹的這個(gè)指令是NgIf,當(dāng)然這個(gè)指令和Angular1的ng-if指令基本上是相似的,根據(jù)后面表達(dá)式的值決定要不要在DOM上添加或者移除一個(gè)元素.

看看我們是如何在模板使用這個(gè)指令的:

<p *ngIf="fruitsList.length > 3">fruitsList's length is bigger than 3</p>
<p *ngIf="fruitsList.length <= 3">fruitsList's length is not bigger than 3</p>
首先要指出的是,和使用*ngFor一樣,我們使用了*ngIf;然后我們可以在*ngIf后面寫上一個(gè)表達(dá)式,這個(gè)表達(dá)式被期望的返回結(jié)果是Boolean類型的值;然后*ngIf指令會(huì)根據(jù)這個(gè)表達(dá)式的值決定要不要在DOM上添加或者移除它掌控的這個(gè)元素.

既然我們使用了TypeScript,我們就可以使用很多新的特性,比如說使用類去構(gòu)建實(shí)例;接下來我們來使用Fruit類來構(gòu)建我們的水果實(shí)例.首先我們?cè)赼pp文件夾下創(chuàng)建一個(gè)新的文件夾,就叫它c(diǎn)lasses吧,然后我們創(chuàng)建一個(gè)Fruit.ts文件,在這里面我們書寫Fruit類的代碼:

export class Fruit{
  constructor(
    public name:string,
    public price: number
  ){}
}

解釋一下上面的代碼,我們使用了構(gòu)造函數(shù),然后在構(gòu)造函數(shù)里面聲明了這個(gè)對(duì)象的兩個(gè)屬性;一個(gè)是name,另一個(gè)是price,我們使用構(gòu)造函數(shù)里面的name:string,和price: number參數(shù)來創(chuàng)建和初始化這個(gè)對(duì)象的屬性.接下來我們就可以在我們的程序中使用這個(gè)類了;

首先在app.component.ts中引入這個(gè)類:

import {Fruit} from './classes/Fruits';
然后在AppComponent中使用Fruit類來初始化我們的水果列表:

export class AppComponent {
  username = 'dreamapple';
  age = 22;
  fruitsList = [
    new Fruit('apple', 20),
    new Fruit('orange', 30),
    new Fruit('pear', 40),
    new Fruit('banana', 50)
  ];
  //noinspection TypeScriptUnresolvedVariable
  fruit = this.fruitsList[0].name; // 這里要使用 this.fruitsList[0]
}

然后也要改一下我們的模板:

復(fù)制代碼 代碼如下:

<li *ngFor="let fruit of fruitsList; let i = index;">{{i}}-{{fruit.name}}-{{fruit.price}}</li>

最后的結(jié)果應(yīng)該是下面這個(gè)樣子:

最后不得不說,無論是ES6,還是TypeScript都讓我感覺到了有種寫Java感覺;這也算有利有弊吧,好處肯定是增加了代碼的可讀性,使程序更加容易維護(hù),也更容易寫出大型的項(xiàng)目,讓團(tuán)隊(duì)協(xié)作也非常的便利;當(dāng)然也有它的一些不足,不足主要是增加了大家的學(xué)習(xí)成本;當(dāng)然一切向前看呀.

相關(guān)文章

  • Angular1.x自定義指令實(shí)例詳解

    Angular1.x自定義指令實(shí)例詳解

    這篇文章主要介紹了Angular1.x自定義指令,結(jié)合實(shí)例形式分析了Angular1.x自定義指令的實(shí)現(xiàn)與使用方法,以及相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
    2017-03-03
  • angularjs select 賦值 ng-options配置方法

    angularjs select 賦值 ng-options配置方法

    下面小編就為大家分享一篇angularjs select 賦值 ng-options配置方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • AngularJS基礎(chǔ) ng-keyup 指令簡(jiǎn)單示例

    AngularJS基礎(chǔ) ng-keyup 指令簡(jiǎn)單示例

    本文主要介紹AngularJS ng-keyup 指令,這里對(duì)ng-keyup指令的基本資料進(jìn)行了整理,并且附有代碼示例,有需要的朋友可以看一下
    2016-08-08
  • angular-ui-sortable實(shí)現(xiàn)可拖拽排序列表

    angular-ui-sortable實(shí)現(xiàn)可拖拽排序列表

    這篇文章主要介紹了angular-ui-sortable實(shí)現(xiàn)可拖拽排序列表,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • Angular中管道操作符(|)的使用方法

    Angular中管道操作符(|)的使用方法

    通常我們需要使用管道實(shí)現(xiàn)對(duì)數(shù)據(jù)的格式化,下面這篇文章主要給大家介紹了關(guān)于Angular中管道操作符(|)的使用方法,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-12-12
  • AngularJS的內(nèi)置過濾器詳解

    AngularJS的內(nèi)置過濾器詳解

    在我們開發(fā)中經(jīng)常需要在頁面顯示給用戶的信息需要一定處理格式化,才能顯示給用戶。在angularjs中為我們提供了叫filter的指令,讓我們能夠很輕易就能做到著一些列的功能,angularjs內(nèi)部為我們提供了number等很多內(nèi)置的filter。
    2015-05-05
  • angularjs中的單元測(cè)試實(shí)例

    angularjs中的單元測(cè)試實(shí)例

    這篇文章主要介紹了angularjs中的單元測(cè)試實(shí)例,本文主要說說利用karma和jasmine來進(jìn)行ng模塊的單元測(cè)試,需要的朋友可以參考下
    2014-12-12
  • AngularJS中的模塊詳解

    AngularJS中的模塊詳解

    這篇文章主要介紹了AngularJS中的模塊詳解,本文給出了一個(gè)模塊實(shí)例,需要的朋友可以參考下
    2015-01-01
  • Angular引入swiper后autoplay失效的解決辦法詳解

    Angular引入swiper后autoplay失效的解決辦法詳解

    這篇文章主要介紹了Angular引入swiper后autoplay失效的解決辦法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • angularjs下ng-repeat點(diǎn)擊元素改變樣式的實(shí)現(xiàn)方法

    angularjs下ng-repeat點(diǎn)擊元素改變樣式的實(shí)現(xiàn)方法

    今天小編就為大家分享一篇angularjs下ng-repeat點(diǎn)擊元素改變樣式的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09

最新評(píng)論