摘要:翻譯教程模版引用變量的魔法原文鏈接作者譯者而井模版引用變量是個(gè)好東西,它允許完成許多有用的事情。所以變量持有了相應(yīng)實(shí)例對(duì)象的任何屬性和方法,如等。它告訴嘿,如果有人想用模版引用變量來指向這個(gè)指令,那么指令的名字就叫做。
【翻譯】【教程】模版引用變量的魔法
原文鏈接:https://blog.angulartraining....
作者:Alain Chautard
譯者:而井
模版引用變量是個(gè)好東西,它允許Angular完成許多有用的事情。我經(jīng)常稱這個(gè)功能為“井號(hào)語法”,因?yàn)樵谀0嬷兴蕾囈粋€(gè)簡(jiǎn)單的井號(hào)來創(chuàng)建對(duì)一個(gè)元素(譯者注:元素包括HTML元素和組件元素)的引用:
上述的語法是如此的簡(jiǎn)潔:它創(chuàng)建了一個(gè)指向input元素的引用,這個(gè)引用稍后可以在我的模版中使用。需要注意的是,這個(gè)(引用)變量的作用域是它所定義的整個(gè)HTML模版(的范圍)(譯者注:即在定義這個(gè)引用變量的HTML模版中都可以訪問這個(gè)變量)。
例如,這里就是我如何用這個(gè)引用來獲取輸入框的值(的例子):
注意那個(gè)phone(變量)指向了input的HTMLElement對(duì)象實(shí)例。所以phone(變量)持有了(相應(yīng))HTMLElement(實(shí)例對(duì)象)的任何屬性和方法,如id、name、innerHTML、value等。
上述是一種避免使用ngModel或其他數(shù)據(jù)綁定的好方法,(因?yàn)椋┻@種方法在校驗(yàn)方面上不需要寫太多代碼。
在組件上也奏效嗎?答案就是可以奏效!假設(shè)我們有HelloWorldComponent如下:
@Component({ selector: "app-hello", template: `` }) export class HelloComponent { name = "Angular"; }Hello {{name}}
現(xiàn)在按照如下代碼,我們使用了“井號(hào)語法”得到了組件的引用:
它(模版引用變量)一個(gè)最好的地方就是我們可以獲取實(shí)際上的組件實(shí)例對(duì)象HelloWorldComponent。所以我們可以訪問這個(gè)組件的任何方法或?qū)傩?,即使他們(的?quán)限)是聲明為私有或保護(hù)的,多么令人驚喜:
{{helloComp.name}}
我們不僅可以通過這種語法來讀取一個(gè)組件的數(shù)據(jù),而且也能修改它。
對(duì)指令也奏效嗎?當(dāng)然(可以),不過這里需要進(jìn)一步了解它(模版引用變量)。大部分的指令將會(huì)被作為(譯者注:HTML或組件標(biāo)簽)的屬性來使用,這意味著我們無法在那里真正應(yīng)用“井號(hào)語法”,除非我們使用相同的語法進(jìn)行扭轉(zhuǎn):
First name value: {{ first.value }}
First name valid: {{ first.valid }}
Form value: {{ f.value | json }}
Form valid: {{ f.valid }}
`, }) export class SimpleFormComp { onSubmit(f: NgForm) { console.log(f.value); // { first: "", last: "" } console.log(f.valid); // false } }文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/100378.html
摘要:注意本文不是關(guān)于如何用編程的方式來創(chuàng)建組件的文章。在這個(gè)例子中,容器元素就是元素,模版將作為這個(gè)元素的兄弟節(jié)點(diǎn)被插入。用來演示以組件自身作為視圖容器,將組件中的模版插入視圖容器的效果。 原文鏈接:https://netbasal.com/angular-...作者:Netanel Basal譯者:而井 showImg(https://segmentfault.com/img/bVbl...
摘要:安裝程序主要通過命令行工具來創(chuàng)建和開發(fā),并使用來構(gòu)建和部署為原生應(yīng)用程序?;A(chǔ)教程確保完成之前的安裝并測(cè)試啟動(dòng)成功。 安裝Ionic Ionic 2 程序主要通過Ionic命令行工具CLI來創(chuàng)建和開發(fā),并使用Cordova來構(gòu)建和部署為原生應(yīng)用程序。也就是說我們需要先安裝一些工具來實(shí)現(xiàn)程序開發(fā)。 安裝Ionic CLI 和 Cordova 要?jiǎng)?chuàng)建 Ionic 2 項(xiàng)目,你需要安裝最新版...
摘要:首先,我們需要在入口頁(yè)面的中配置根路徑然后創(chuàng)建一個(gè)路由模塊路由配置在主模塊中導(dǎo)入配置好的路由模塊而在頁(yè)面中需要一個(gè)容器去承載上面代碼中的定義了用戶點(diǎn)擊后的路由跳轉(zhuǎn),定義該路由激活時(shí)的樣式類。 剛實(shí)習(xí)的時(shí)候用過AngularJS,那時(shí)候真的是連原生JavaScript都不會(huì)寫,依樣畫葫蘆做了幾個(gè)管理后臺(tái)。然后突然換項(xiàng)目了,AngularJS就不寫了,感覺前前后后接觸了一年多的Angula...
摘要:最近在看,隨手記的一些的隨筆。新上手或者準(zhǔn)備學(xué)的可以用作參考,第一次寫博客,筆記不算完整,若老司機(jī)發(fā)現(xiàn)有不足指出請(qǐng)指出。處理當(dāng)前路由離開的情況。在路由激活之前獲取路由數(shù)據(jù)。 最近在看angular4,隨手記的一些angular的隨筆。 新上手或者準(zhǔn)備學(xué)angular的可以用作參考,第一次寫博客,筆記不算完整,若老司機(jī)發(fā)現(xiàn)有不足指出請(qǐng)指出。 技術(shù)交流群:513590751 Angular...
摘要:最近在看,隨手記的一些的隨筆。新上手或者準(zhǔn)備學(xué)的可以用作參考,第一次寫博客,筆記不算完整,若老司機(jī)發(fā)現(xiàn)有不足指出請(qǐng)指出。處理當(dāng)前路由離開的情況。在路由激活之前獲取路由數(shù)據(jù)。 最近在看angular4,隨手記的一些angular的隨筆。 新上手或者準(zhǔn)備學(xué)angular的可以用作參考,第一次寫博客,筆記不算完整,若老司機(jī)發(fā)現(xiàn)有不足指出請(qǐng)指出。 技術(shù)交流群:513590751 Angular...
閱讀 3699·2021-11-24 09:39
閱讀 1311·2021-09-30 09:48
閱讀 3308·2021-09-09 11:51
閱讀 2927·2021-09-08 10:41
閱讀 1359·2019-08-30 14:06
閱讀 2829·2019-08-30 14:01
閱讀 898·2019-08-29 17:11
閱讀 3203·2019-08-29 15:37