Angular4 中內(nèi)置指令的基本用法
前言
大家都知道ng內(nèi)置了許多自定義的指令,這避免了我們自己去造輪子。同時,ng也提供了自定義指令的功能,可以讓我們的頁面元素標簽更加實例化。
在這篇文章中,我們將分別列舉每一個內(nèi)置指令的用法,并提供一個例子作為演示。盡量用最少最簡單的描述,讓你在更快更準確地學會每一種內(nèi)置指令的基本用法。
ngFor
作用:像 for 循環(huán)一樣,可以重復的從數(shù)組中取值并顯示出來。
例子:
// .ts
this.userInfo = ['張三', '李四', '王五'];
// .html
<div class="ui list" *ngFor="let username of userInfo">
<div class="item">{{username}}</div>
</div>
講解:
他的語法是 *ngFor="let username of userInfo" ,其中 userInfo 是從中取值的數(shù)組,username 是每次從中取出來的值。然后在這個標簽里面的內(nèi)容就會重復執(zhí)行,并通過雙向綁定,將 username 顯示出來。
ngIf
作用:根據(jù)條件決定是否顯示或隱藏這個元素。
例子:
// .html <div *ngIf="false"></div> <div *ngIf="a > b"></div> <div *ngIf="username == '張三'"></div> <div *ngIf="myFunction()"></div>
講解:
- 永遠不會顯示
- 當 a 大于 b 的時候顯示
- 當 username 等于 張三 的時候顯示
- 根據(jù) myFunction() 這個函數(shù)的返回值,決定是否顯示
ngSwitch
作用:防止條件復雜的情況導致過多的使用 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] 先與目標進行綁定,ngSwitchCase 列出每個可能性,ngSwitchDefault 列出默認值。
ngStyle
作用:可以使用動態(tài)值給特定的 DOM 元素設定 CSS 屬性。
例子:
// .ts
backColor: 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>
講解:
- 直接設置顏色為 yellow。
- 設置背景顏色為 backColor,并可以在 .ts 文件中對 backColor 的值進行修改。
- 設置字體大小,需要注意的是 只寫 font-size 會報錯,必須在后面加上 .px。當然 .em .% 都是可以的。
- 前三種都是只設置一個,寫 [ngStyle] 可以同時寫多個,使用花括號包住里面的內(nèi)功。需要注意的是連字符 - 是不允許出現(xiàn)在對象的鍵名當中的,如果使用 background-color 等時需要加上單引號。
ngClass
作用:動態(tài)地設置和改變一個給定 DOM 元素的 CSS類。
例子:
// .scss
.bordered {
border: 1px dashed black;
background-color: #eee;
}
// .ts
isBordered: boolean = true;
// .html
<div [ngClass]="{bordered: isBordered}">
是否顯示邊框
</div>
講解:
- scss 中設置了樣式,相當于你建了一個
class="bordered"。 - ts 中新建了一個 isBordered,用于判斷是否顯示 .scss 中的樣式。
- html 中用 isBordered 作為 bordered 是否顯示 的判斷依據(jù)。
ngNonBindable
作用:告訴 Angular 不要綁定頁面的某個部分。
例子:
.html
<div ngNonBindable>
{{我不會被綁定}}
</div>
講解:
使用了 ngNonBindable ,花括號就會被當做字符串一起顯示出來。
總結(jié)
日常開發(fā)中,用 ngFor 和 ngIf 應該是最多的了,所以把他們兩個寫在了前面。至于 ngNonBindable,我實際開發(fā)中一次沒用過,也是查著資料測試一遍寫下來的。
好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持
相關文章
Angular中的ng-template及angular 使用ngTemplateOutlet 指令的方法
ng-template 是用來定義模板的,當使用ng-template定義好一個模板之后,可以用ng-container和templateOutlet指令來進行使用。這篇文章給大家介紹了Angular中的ng-templateangular及使用 ngTemplateOutlet 指令的方法,需要的朋友參考下吧2018-08-08
Angularjs的$http異步刪除數(shù)據(jù)詳解及實例
這篇文章主要介紹了Angularjs的$http異步刪除數(shù)據(jù)詳解及實例的相關資料,這里提供實現(xiàn)思路及實現(xiàn)具體的方法,需要的朋友可以參考下2017-07-07

