国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

Angular4 中內(nèi)置指令的基本用法

2019-11-19 15:56:36
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

前言

大家都知道ng內(nèi)置了許多自定義的指令,這避免了我們自己去造輪子。同時(shí),ng也提供了自定義指令的功能,可以讓我們的頁(yè)面元素標(biāo)簽更加實(shí)例化。

在這篇文章中,我們將分別列舉每一個(gè)內(nèi)置指令的用法,并提供一個(gè)例子作為演示。盡量用最少最簡(jiǎn)單的描述,讓你在更快更準(zhǔn)確地學(xué)會(huì)每一種內(nèi)置指令的基本用法。

ngFor

作用:像 for 循環(huán)一樣,可以重復(fù)的從數(shù)組中取值并顯示出來(lái)。

例子:

// .tsthis.userInfo = ['張三', '李四', '王五'];// .html<div class="ui list" *ngFor="let username of userInfo"> <div class="item">{{username}}</div></div>

講解:

他的語(yǔ)法是 *ngFor="let username of userInfo" ,其中 userInfo 是從中取值的數(shù)組,username 是每次從中取出來(lái)的值。然后在這個(gè)標(biāo)簽里面的內(nèi)容就會(huì)重復(fù)執(zhí)行,并通過(guò)雙向綁定,將 username 顯示出來(lái)。

ngIf

作用:根據(jù)條件決定是否顯示或隱藏這個(gè)元素。

例子:

// .html<div *ngIf="false"></div><div *ngIf="a > b"></div><div *ngIf="username == '張三'"></div><div *ngIf="myFunction()"></div>

講解:

  • 永遠(yuǎn)不會(huì)顯示
  • 當(dāng) a 大于 b 的時(shí)候顯示
  • 當(dāng) username 等于 張三 的時(shí)候顯示
  • 根據(jù) myFunction() 這個(gè)函數(shù)的返回值,決定是否顯示

ngSwitch

作用:防止條件復(fù)雜的情況導(dǎo)致過(guò)多的使用 ngIf。

例子:

// .html<div class="container" [ngSwitch]="myAge"> <div *ngSwitchCase="'10'">age = 10</div> <div *ngSwitchCase="'20'">age = 20</div> <div *ngSwitchDefault="'18'">age = 18</div></div>

講解:

[ngSwitch] 先與目標(biāo)進(jìn)行綁定,ngSwitchCase 列出每個(gè)可能性,ngSwitchDefault 列出默認(rèn)值。

ngStyle

作用:可以使用動(dòng)態(tài)值給特定的 DOM 元素設(shè)定 CSS 屬性。

例子:

// .tsbackColor: string = 'red';// .html<div [style.color]="yellow"> 你好,世界</div><div [style.background-color]="backColor"> 你好,世界</div><div [style.font-size.px]="20"> 你好,世界</div><div [ngStyle]="{color: 'white', 'background-color': 'blue', 'font-size.px': '20'}"> 你好,世界</div>

講解:

  • 直接設(shè)置顏色為 yellow。
  • 設(shè)置背景顏色為 backColor,并可以在 .ts 文件中對(duì) backColor 的值進(jìn)行修改。
  • 設(shè)置字體大小,需要注意的是 只寫(xiě) font-size 會(huì)報(bào)錯(cuò),必須在后面加上 .px。當(dāng)然 .em .% 都是可以的。
  • 前三種都是只設(shè)置一個(gè),寫(xiě) [ngStyle] 可以同時(shí)寫(xiě)多個(gè),使用花括號(hào)包住里面的內(nèi)功。需要注意的是連字符 - 是不允許出現(xiàn)在對(duì)象的鍵名當(dāng)中的,如果使用 background-color 等時(shí)需要加上單引號(hào)。

ngClass

作用:動(dòng)態(tài)地設(shè)置和改變一個(gè)給定 DOM 元素的 CSS類。

例子:

// .scss.bordered { border: 1px dashed black; background-color: #eee;}// .tsisBordered: boolean = true; // .html<div [ngClass]="{bordered: isBordered}"> 是否顯示邊框</div>

講解:

  • scss 中設(shè)置了樣式,相當(dāng)于你建了一個(gè) class="bordered" 。
  • ts 中新建了一個(gè) isBordered,用于判斷是否顯示 .scss 中的樣式。
  • html 中用 isBordered 作為 bordered 是否顯示 的判斷依據(jù)。

ngNonBindable

作用:告訴 Angular 不要綁定頁(yè)面的某個(gè)部分。

例子:

.html<div ngNonBindable> {{我不會(huì)被綁定}}</div>

講解:

使用了 ngNonBindable ,花括號(hào)就會(huì)被當(dāng)做字符串一起顯示出來(lái)。

總結(jié)

日常開(kāi)發(fā)中,用 ngFor 和 ngIf 應(yīng)該是最多的了,所以把他們兩個(gè)寫(xiě)在了前面。至于 ngNonBindable,我實(shí)際開(kāi)發(fā)中一次沒(méi)用過(guò),也是查著資料測(cè)試一遍寫(xiě)下來(lái)的。

好了,以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)武林網(wǎng)的支持

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 海城市| 中山市| 岑溪市| 宾阳县| 新田县| 河北区| 钦州市| 银川市| 南澳县| 张家港市| 永宁县| 牟定县| 定西市| 建德市| 崇信县| 英吉沙县| 太湖县| 昌邑市| 土默特左旗| 翁牛特旗| 墨江| 临武县| 七台河市| 西畴县| 台安县| 仪征市| 水城县| 汾西县| 湖州市| 龙门县| 徐水县| 怀柔区| 开鲁县| 普兰县| 衢州市| 罗定市| 建水县| 西乡县| 扎赉特旗| 房山区| 阿鲁科尔沁旗|