Angular模版篇

Angular 模板

什么是模板

???????在 Angular 中,組件扮演著控制器或視圖模型的角色,模板則扮演視圖的角色。模板是一種自定義的標(biāo)準(zhǔn)化頁(yè)面,通過(guò)模板和模板中的數(shù)據(jù)結(jié)合,可以生產(chǎn)各種各樣的網(wǎng)頁(yè)。在Angular中,模板的默認(rèn)語(yǔ)言是HTML,幾乎所有的HTML語(yǔ)法在模板中都是適用的,但<script>標(biāo)簽是被禁止的,主要是為了防止JavaScript腳本注入攻擊(XXS)。同時(shí)一些HTML元素在模板中并不起什么作用,比如<html>、<body>、<base>等。除此之外,Angular中可以通過(guò)組件和指令對(duì)模板的HTML元素進(jìn)行擴(kuò)展,這些擴(kuò)展將以新的元素或?qū)傩缘男问匠霈F(xiàn)。

模板表達(dá)式

???????模板表達(dá)式類似于JavaScript語(yǔ)言的表達(dá)式,絕大部分的JavaScript表達(dá)式都是合法的模板表達(dá)式。模板表達(dá)式應(yīng)用在插值語(yǔ)法的雙大括號(hào)中和屬性綁定“=”右側(cè)的引號(hào)中。Angular會(huì)執(zhí)行這個(gè)表達(dá)式并將值分配給一個(gè)綁定目標(biāo)的屬性,這個(gè)綁定目標(biāo)可能是一個(gè)HTML元素、組件或者指令。

注意不能為一下幾種情況:

  1. 帶有new運(yùn)算符的表達(dá)式。
  2. 賦值表達(dá)式(=、+=、-=)等。
  3. 帶有;或者,的鏈?zhǔn)奖磉_(dá)式。
  4. 帶有自增和自減操作(++/--)的表達(dá)式
  5. 不支持位運(yùn)算符(| 和&)

還能使用三元表達(dá)式

<p [style.color]="isColor ? 'blue' : 'black'">daocheng</p>

語(yǔ)法大全

1506273768(1).png
1506273788(1).png

數(shù)據(jù)綁定

Angular中不論是從組件控制器中的屬性綁定到模板上,還是從模板中的事件反映到控制器中,它們都默認(rèn)是單向的。

1.插值表達(dá)式

語(yǔ)法:{{ }},也是單向綁定

2.事件綁定

數(shù)據(jù)從模板流向組件類。在事件綁定中,Angular通過(guò)監(jiān)聽(tīng)用戶操作事件,比如鍵盤事件、鼠標(biāo)事件等來(lái)執(zhí)行其對(duì)應(yīng)綁定的方法。事件綁定的語(yǔ)法是由“=”左側(cè)小括號(hào)內(nèi)的目標(biāo)事件和“=”右側(cè)引號(hào)中的目標(biāo)語(yǔ)句組成。示例 (click)=”onClick”

類型

  1. 綁定自定義事件。場(chǎng)景:子組件@Output發(fā)射出來(lái)的事件。
  2. DOM原生事件。事件一覽表https://developer.mozilla.org/zh-CN/docs/Web/Events
3.屬性綁定

在學(xué)習(xí)屬性綁定前先來(lái)了解一對(duì)非常重要的概念,即DOM對(duì)象屬性(Property)與HTML標(biāo)簽特性(Attribute)。在英語(yǔ)中Property和Attribute都可以譯為‘屬性’,名字雖然相同,但在模板中意義卻大有不同。

兩者的區(qū)別和聯(lián)系還體現(xiàn)在以下兩個(gè)方面:

  1. 大多數(shù)情況下,DOM對(duì)象屬性與HTML標(biāo)簽特性并不是一一對(duì)應(yīng)的,但有少量屬性即是DOM對(duì)象屬性又是HTML標(biāo)簽特性,如id、title、class等。
  2. 通常HTML標(biāo)簽特性代表初始值,初始化以后就不發(fā)生改變,而DOM元素對(duì)象屬性代表當(dāng)前值,其默認(rèn)為初始值但是會(huì)隨著改變。

實(shí)際的使用:大多數(shù)情況我們都是綁定DOMProperty屬性,而有些特例你只能綁定attr(colspan,我們table中的標(biāo)簽屬性)[attr.colspan]

4.雙向數(shù)據(jù)綁定

我們經(jīng)常需要顯示數(shù)據(jù)屬性,并在用戶作出更改時(shí)更新該屬性。
在元素層面上,既要設(shè)置元素屬性,又要監(jiān)聽(tīng)元素事件變化。
Angular 為此提供一種特殊的雙向數(shù)據(jù)綁定語(yǔ)法:[(x)]。 [(x)]語(yǔ)法結(jié)合了屬性綁定的方括號(hào)[x]和事件綁定的圓括號(hào)(x)。

原理:
一個(gè) @Input xxx 加上 @Output xxxChange,構(gòu)成 [( xxx )];

5.模板引用變量

模板引用變量通常用來(lái)引用模板中的某個(gè)DOM元素,它還可以引用Angular組件或指令或Web Component。示例:使用井號(hào) (#) 來(lái)聲明引用變量。也可以使用ref-前綴代替。

6.模板表達(dá)式操作符
  1. 管道操作符 ( | )
  2. 安全導(dǎo)航操作符 ( ?. ) 和空屬性路徑
  3. 非空斷言操作符 ( ! ) //需要特點(diǎn)的場(chǎng)景

管道

在Angular中,管道(Pipes)可以按照開(kāi)發(fā)者指定的規(guī)則將模板內(nèi)的數(shù)據(jù)進(jìn)行轉(zhuǎn)換。如日期類型(Date),默認(rèn)會(huì)顯示為Mon Sep 18 2017 17:16:11 GMT+0800 (中國(guó)標(biāo)準(zhǔn)時(shí)間)這樣的形式,但不如Sep 18,2017這樣的形式直觀,此時(shí)可以借助管道來(lái)實(shí)現(xiàn)這種轉(zhuǎn)換效果。

1. 管道介紹

使用管道,需要用管道操作符 | 來(lái)連接模板表達(dá)式中左邊的輸入數(shù)據(jù)和右邊的管道,示例:{{birthday | date }}

2.管道參數(shù)

管道可以使用參數(shù),示例:

{{birthday | date:”y/MM/dd” }} 通過(guò)傳入的參數(shù)來(lái)輸出不同格式的數(shù)據(jù)
y代表年, M代表月份,d代表天, H代表小時(shí),m代表分鐘,s代表秒

3.鏈?zhǔn)焦艿?/h5>

一個(gè)模板表達(dá)式可以連續(xù)使用多個(gè)管道進(jìn)行不同的處理,這就是鏈?zhǔn)焦艿馈J褂面準(zhǔn)焦艿揽梢哉故靖S富的數(shù)據(jù)格式,語(yǔ)法格式如下所示:
{{birthday | date| uppercase}}

4.常用內(nèi)置管道

1.DatePipe ( 用來(lái)格式化一個(gè)日期數(shù)據(jù) )

2.JsonPipe ( 通過(guò)JSON.stringify()來(lái)將輸入數(shù)據(jù)對(duì)象轉(zhuǎn)換成對(duì)象字符串,主要用于開(kāi)發(fā)調(diào)試。示例:{{jsonObject | json }} )

3.DecimalPipe ( 用于對(duì)數(shù)值的整數(shù)與小數(shù)部分按照指定規(guī)則進(jìn)行格式化,這種格式化方式也稱為本地格式化處理,示例:
expression| number[: {minIntegerDigits}.{minFractionDigits}-{maxFractionDigits}]
)

4.內(nèi)置管道全家福:( linkhttps://www.angular.cn/api?type=pipe )

5.自定義管道

雖然Angular提供了許多內(nèi)置的管道,但是數(shù)據(jù)轉(zhuǎn)換涉及各種各樣的格式,內(nèi)置管道顯然無(wú)法滿足全部需求,因此我們需要使用Angular提供的自定義管道功能來(lái)實(shí)現(xiàn)更多的需求。
命令:ng g p xxx

步驟:

  1. 新建一個(gè)pipe, ng g p sexreform
  2. Angular就會(huì)在根模塊中進(jìn)行處理。
  3. 實(shí)現(xiàn)一個(gè)transform的方法,第一個(gè)參數(shù)是被管道的值,第二個(gè)參數(shù)是我們的管道參數(shù)(可選)。需要返回被處理完之后的值

注意:

  1. @Pipe裝飾器裝飾的。
  2. name元數(shù)據(jù)的值決定了管道的使用名稱。
  3. ==管道并不會(huì)改變?cè)紨?shù)據(jù)的值,只是進(jìn)行了一個(gè)格式化==

6.管道分類

==純管道==:Angular只有在它檢測(cè)到輸入值發(fā)生了純變更時(shí)才會(huì)執(zhí)行純管道。純變更是指對(duì)原始類型值(String、Number、Boolean、Symbol)的更改,或者對(duì)對(duì)象引用(Date、Array、Function、Object)的更改。

==非純管道==:Angular會(huì)在每個(gè)組件的變更檢測(cè)周期中執(zhí)行非純管道。非純管道可能會(huì)被調(diào)用很多次,和每個(gè)按鍵或每次鼠標(biāo)移動(dòng)一樣頻繁。示例:| async(Rxjs中會(huì)提到)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,517評(píng)論 6 539
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,087評(píng)論 3 423
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 177,521評(píng)論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 63,493評(píng)論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,207評(píng)論 6 410
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 55,603評(píng)論 1 325
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,624評(píng)論 3 444
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 42,813評(píng)論 0 289
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,364評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,110評(píng)論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,305評(píng)論 1 371
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,874評(píng)論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,532評(píng)論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 34,953評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 36,209評(píng)論 1 291
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,033評(píng)論 3 396
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,268評(píng)論 2 375

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