指令,我將其理解為AngularJS操作HTML element的一種途徑。
由於學習AngularJS的第一步就是寫內建指令ng-app以指出該節點是應用的根節點,所以指令早已不陌生。
這篇日誌簡單記錄了一些內建指令,先使用起來,再談一些有趣的東西。
內建指令
所有的內建指令的前綴都是ng,不建議自訂指令使用該前綴,以免衝突。
首先從一些常見的內建指令開始。
先列出一些關鍵的內建指令,順便簡單說說作用域的問題。
ng-model
將表單控制項和目前作用域的屬性綁定,這麼解釋似乎也不太正確。
但先不要管咬文嚼字,用起來倒是易懂,例如:
ng-init
指令被呼叫時會初始化內部作用域。
這個指令一般會出現在比較小的應用中,例如給個demo什麼的...
除了ng-init,我們還有更多更好的選擇。
ng-app
每次用AngularJS都離不開這個指令,順便說下$rootScope。
聲明了ng-app的元素會成為$rootScope的起點,而$rootScope是作用域鏈的根,通常聲明在你懂的。
也就是說根下的作用域都可以存取它。
但是,不建議過度使用$rootScope,免得全域變數滿天飛,效率又差又難管。
下面是一個例子:
ng-controller
我們用這個指令在一個DOM元素上裝上controller。
一個控制器? 確實,從字面意思上這樣理解倒是不錯,那我們為什麼需要控制器?
記得AngularJS 1.2.x時還可以這樣定義controller來著...
AngularJS 1.3.x中禁止了這種方式,因為這種方式會讓controller滿天飛,分不清層次,所有東西都掛在$rootScope上...
ng-controller必須有一個表達式作為參數,另外透過$scope來繼承上級$scope的方法和屬性什麼的,$rootScope也包括在內。
下面只是一個簡單的例子,ancestor無法存取child的作用域。
作用域的問題遠不止如此,暫且擱下,繼續看看其他內建指令。
ng-form
一開始不明白為什麼會有表單指令,