Angular 4 常用指令入門(mén)

NgIf

<div *ngIf="false"></div> <!-- never displayed -->
<div *ngIf="a > b"></div> <!-- displayed if a is more than b -->
<div *ngIf="str == 'yes'"></div> <!-- displayed if str holds the string "yes" -->
<div *ngIf="myFunc()"></div> <!-- displayed if myFunc returns a true value -->

NgSwitch

有時(shí)候需要根據(jù)不同的條件崔步,渲染不同的元素村视,此時(shí)我們可以使用多個(gè) ngIf 來(lái)實(shí)現(xiàn)坚弱。

<div class="container">
    <div *ngIf="myVar == 'A'">Var is A</div>
    <div *ngIf="myVar == 'B'">Var is B</div>
    <div *ngIf="myVar != 'A' && myVar != 'B'">Var is something else</div>
</div>  

如果 myVar 的可選值多了一個(gè) 'C'斧拍,就得相應(yīng)增加判斷邏輯:

<div class="container">
    <div *ngIf="myVar == 'A'">Var is A</div>
    <div *ngIf="myVar == 'B'">Var is B</div>
    <div *ngIf="myVar == 'C'">Var is C</div>
    <div *ngIf="myVar != 'A' && myVar != 'B' && myVar != 'C'">
      Var is something else
    </div>
</div>

可以發(fā)現(xiàn) Var is something else 的判斷邏輯雀扶,會(huì)隨著 myVar 可選值的新增,變得越來(lái)越復(fù)雜肆汹。遇到這種情景愚墓,我們可以使用 ngSwitch 指令。

<div class="container" [ngSwitch]="myVar">
    <div *ngSwitchCase="'A'">Var is A</div>
    <div *ngSwitchCase="'B'">Var is B</div>
    <div *ngSwitchCase="'C'">Var is C</div>
    <div *ngSwitchDefault>Var is something else</div>
</div>

NgStyle

NgStyle 讓我們可以方便得通過(guò) Angular 表達(dá)式昂勉,設(shè)置 DOM 元素的 CSS 屬性浪册。

  • 設(shè)置元素的背景顏色
<div [style.background-color="'yellow'"]>
  Use fixed yellow background
</div> 
  • 設(shè)置元素的字體大小
<!-- 支持單位: px | em | %-->
<div>
   <span [ngStyle]="{color: 'red'}" [style.font-size.px]="fontSize">
      red text
   </span>
</div>

NgStyle 支持通過(guò)鍵值對(duì)的形式設(shè)置 DOM 元素的樣式:

<div [ngStyle]="{color: 'white', 'background-color': 'blue'}">
   Uses fixed white text on blue background
</div>

注意到 background-color 需要使用單引號(hào),而 color 不需要岗照。這其中的原因是村象,ng-style 要求的參數(shù)是一個(gè) Javascript 對(duì)象笆环,color 是一個(gè)有效的 key,而 background-color 不是一個(gè)有效的 key 厚者,所以需要添加 ''咧织。

NgClass

NgClass 接收一個(gè)對(duì)象字面量,對(duì)象的 key 是 CSS class 的名稱(chēng)籍救,value 的值是 truthy/falsy 的值习绢,表示是否應(yīng)用該樣式。

  • CSS Class
.bordered {
    border: 1px dashed black; background-color: #eee;
}
  • HTML
<!-- Use boolean value -->
<div [ngClass]="{bordered: false}">This is never bordered</div>
<div [ngClass]="{bordered: true}">This is always bordered</div>

<!-- Use component instance property -->
<div [ngClass]="{bordered: isBordered}">
   Using object literal. Border {{ isBordered ? "ON" : "OFF" }}
</div>

<!-- Class names contains dashes -->
<div[ngClass]="{'bordered-box': false}">
   Class names contains dashes must use single quote
</div>

<!-- Use a list of class names -->
<div class="base" [ngClass]="['blue', 'round']"> 
  This will always have a blue background and round corners
</div>

NgFor

NgFor 指令用來(lái)根據(jù)集合(數(shù)組) 蝙昙,創(chuàng)建 DOM 元素闪萄,類(lèi)似于 ng1ng-repeat 指令

<div class="ui list" *ngFor="let c of cities; let num = index"> 
  <div class="item">{{ num+1 }} - {{ c }}</div>
</div>

使用 trackBy 提高列表的性能

@Component({
  selector: 'my-app',
  template: `
    <ul>
      <li *ngFor="let item of collection;trackBy: trackByFn">{{item.id}}</li>
    </ul>
    <button (click)="getItems()">Refresh items</button>
  `,
})
export class App {

  constructor() {
    this.collection = [{id: 1}, {id: 2}, {id: 3}];
  }
  
  getItems() {
    this.collection = this.getItemsFromServer();
  }
  
  getItemsFromServer() {
    return [{id: 1}, {id: 2}, {id: 3}, {id: 4}];
  }
  
  trackByFn(index, item) {
    return index; // or item.id
  }
}

NgNonBindable

ngNonBindable 指令用于告訴 Angular 編譯器,無(wú)需編譯頁(yè)面中某個(gè)特定的HTML代碼片段奇颠。

<div class='ngNonBindableDemo'>
    <span class="bordered">{{ content }}</span>
    <span class="pre" ngNonBindable>
      ← This is what {{ content }} rendered
    </span>
</div>

Angular 4.x 新特性

If...Else Template Conditions

語(yǔ)法

<element *ngIf="[condition expression]; else [else template]"></element>

使用示例

<ng-template #hidden>
  <p>You are not allowed to see our secret</p>
</ng-template>
<p *ngIf="shown; else hidden">
  Our secret is being happy
</p>

<template> —> <ng-template>

使用示例

import { Component, OnInit } from '@angular/core';
import { Observable } from 'rxjs/Observable';
import 'rxjs/add/observable/of';
import 'rxjs/add/operator/delay';

@Component({
  selector: 'exe-app',
  template: `
   <ng-template #fetching>
      <p>Fetching...</p>
   </ng-template>
   <p *ngIf="auth | async; else fetching; let user">
      {{user.username }}
   </p>
  `,
})
export class AppComponent implements OnInit {
  auth: Observable<{}>;

  ngOnInit() {
    this.auth = Observable
      .of({ username: 'semlinker', password: 'segmentfault' })
      .delay(new Date(Date.now() + 2000));
  }
}

我有話(huà)說(shuō)

使用 [hidden] 屬性控制元素可見(jiàn)性存在的問(wèn)題

<div [hidden]="!showGreeting">
  Hello, there!
</div>

上面的代碼在通常情況下败去,都能正常工作。但當(dāng)在對(duì)應(yīng)的 DOM 元素上設(shè)置 display: flex 屬性時(shí)烈拒,盡管[hidden] 對(duì)應(yīng)的表達(dá)式為 true圆裕,但元素卻能正常顯示。對(duì)于這種特殊情況荆几,則推薦使用 *ngIf吓妆。

直接使用 DOM API 獲取頁(yè)面上的元素存在的問(wèn)題

@Component({
  selector: 'my-comp',
  template: `
    <input type="text" />
    <div> Some other content </div>
  `
})
export class MyComp {
  constructor(el: ElementRef) {
    el.nativeElement.querySelector('input').focus();
  }
}

以上的代碼直接通過(guò) querySelector() 獲取頁(yè)面中的元素,通常不推薦使用這種方式吨铸。更好的方案是使用 @ViewChild 和模板變量行拢,具體示例如下:

@Component({
  selector: 'my-comp',
  template: `
    <input #myInput type="text" />
    <div> Some other content </div>
  `
})
export class MyComp implements AfterViewInit {
  @ViewChild('myInput') input: ElementRef;

  constructor(private renderer: Renderer) {}

  ngAfterViewInit() {
    this.renderer.invokeElementMethod(
        this.input.nativeElement, 'focus');
    }
}

另外值得注意的是,@ViewChild() 屬性裝飾器诞吱,還支持設(shè)置返回對(duì)象的類(lèi)型舟奠,具體使用方式如下:

@ViewChild('myInput') myInput1: ElementRef;
@ViewChild('myInput', {read: ViewContainerRef}) myInput2: ViewContainerRef;

若未設(shè)置 read 屬性,則默認(rèn)返回的是 ElementRef 對(duì)象實(shí)例房维。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末沼瘫,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子咙俩,更是在濱河造成了極大的恐慌耿戚,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,591評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件暴浦,死亡現(xiàn)場(chǎng)離奇詭異溅话,居然都是意外死亡晓锻,警方通過(guò)查閱死者的電腦和手機(jī)歌焦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)砚哆,“玉大人独撇,你說(shuō)我怎么就攤上這事。” “怎么了纷铣?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,823評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵卵史,是天一觀(guān)的道長(zhǎng)。 經(jīng)常有香客問(wèn)我搜立,道長(zhǎng)以躯,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,204評(píng)論 1 292
  • 正文 為了忘掉前任啄踊,我火速辦了婚禮忧设,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘颠通。我一直安慰自己址晕,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布顿锰。 她就那樣靜靜地躺著谨垃,像睡著了一般。 火紅的嫁衣襯著肌膚如雪硼控。 梳的紋絲不亂的頭發(fā)上刘陶,一...
    開(kāi)封第一講書(shū)人閱讀 51,190評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音牢撼,去河邊找鬼易核。 笑死,一個(gè)胖子當(dāng)著我的面吹牛浪默,可吹牛的內(nèi)容都是我干的牡直。 我是一名探鬼主播,決...
    沈念sama閱讀 40,078評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼纳决,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼碰逸!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起阔加,我...
    開(kāi)封第一講書(shū)人閱讀 38,923評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤饵史,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后胜榔,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體胳喷,經(jīng)...
    沈念sama閱讀 45,334評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評(píng)論 2 333
  • 正文 我和宋清朗相戀三年夭织,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了吭露。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,727評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡尊惰,死狀恐怖讲竿,靈堂內(nèi)的尸體忽然破棺而出泥兰,到底是詐尸還是另有隱情,我是刑警寧澤题禀,帶...
    沈念sama閱讀 35,428評(píng)論 5 343
  • 正文 年R本政府宣布鞋诗,位于F島的核電站,受9級(jí)特大地震影響迈嘹,放射性物質(zhì)發(fā)生泄漏削彬。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評(píng)論 3 326
  • 文/蒙蒙 一秀仲、第九天 我趴在偏房一處隱蔽的房頂上張望吃警。 院中可真熱鬧,春花似錦啄育、人聲如沸酌心。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,672評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)安券。三九已至,卻和暖如春氓英,著一層夾襖步出監(jiān)牢的瞬間侯勉,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,826評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工铝阐, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留址貌,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,734評(píng)論 2 368
  • 正文 我出身青樓徘键,卻偏偏與公主長(zhǎng)得像练对,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子吹害,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容