1、AngularJS的模板綁定機制好像和其$http服務也有一定關係,如果用jQuery Ajax的傳回值賦給$scope的範圍變數,整個綁定顯示的節奏慢一個事件,神器果然麻煩啊。
2、對hidden input做綁定好像無效
3、AngularJS中對input的ng-model綁定和對Input的value賦值之間存在矛盾。如果綁定了model就無法對value做賦值。
4、input不做ng-model綁定,那驗證輸入的機制就會有問題:錯誤提示顯示不出來。觀察Scope,你會發現,那段input對應的error值根本不存在。
5、根據3和4兩個條件,對錶單資料做初始化最好用ng-model,對$scope的變數做初始化時,只能對一級子屬性複製比如$scope.attr1,如果直接對二級屬性,$scope.attr1.attr2賦值,因為第一次初始化時可能$scope.attr1這個對象實際還沒有建立,會導致代碼出錯。
6、關於依賴的注入辦法,網上有篇文章作了總結:http://www.cnblogs.com/lcllao/archive/2012/09/23/2699401.html。文章給出的依賴注入推薦方法是:
var MyController = function(dep1, dep2) { ...}MyController.$inject = ['dep1', 'dep2'];MyController.prototype.aMethod = function() { ...}
但是遺憾的是這種方法對非Provider的依賴注入是無效的,所以比較保險的方法還是AngularJS一書最開始14頁給出的方法:
var myAppModule = angular.module('myApp', []);myAppModule.controller('TextController', function($scope) { var someText = {}; someText.message = 'You have started your journey.'; $scope.someText = someText; });
這個方法最麻煩的是你得在HTML的ng-app那兒加一個“myApp”此類的屬性值,而且這個地方有個問題就是個你得myapp得用JS定義,否則JS運行會出錯,我個人建議
var myApp = angular.module('myApp',[]);
這麼一條語句要放在網站個人化定製代碼的第一行。