AngularJS 遇到的小坑与技巧小结
1.templateURL和路由之类的要在webserver下运行。
2.使用模板replace设为true,模板里也要有相应的标签,否则不出现任何数据。
3.1.2版本之后,ngRoute模块独立。
4.空的controller不定义会出错。
5.Directive的link参数是有顺序的:scope,element,attrs,ctrl
6.ng-repeat不能循环重复的对象。hack:ng-repeat="thinginthingstrackby$id($index)"
7.尽量更新的是变量的属性而不是单个变量本身。
8.注意ng-repeat,ng-controller等会产生独立作用域。
9.当jquery载入,则使用jquery,否则使用内置jqlite。allelementreferencesinAngulararealwayswrappedwithjQueryorjqLite;theyareneverrawDOMreferences.
10.UncaughtError:[$location:ihshprfx] A标签没有去掉<ahref="#"ng-click="someMethod();"></a>
11.Error:listenEACCES当在linux下,会出现这个错误,因为你监听的端口的原因,这里我的是33。把它改成8080或3030之类大的端口数就可以了。有一个规定,这些端口最好是大于1024。
12.select在没有ng-model的时候,无法显示。同理,当遇到无法显示最好看文档少了什么。
补:当ng-options的源,跟书写不相配时会出现全部选择的情况,如下:
vara=[{"id":1,"name":"Ryan"}....],ng-options="item.iasitem.nameforitemina" //i与id不同
----------------------------------------------------------------------------------------
13.ng-bind-html-unsafe已去除,可以用['ngSanitize']模块或使用$sce服务
Fromstackoverflow
Youindicatedthatyou'reusingAngular1.2.0...asoneoftheothercommentsindicated,ng-bind-html-unsafehasbeendeprecated.
Instead,you'llwanttodosomethinglikethis:
<divng-bind-html="preview_data.preview.embed.htmlSafe"></div>
Inyourcontroller,injectthe$sceservice,andmarktheHTMLas"trusted":
myApp.controller('myCtrl',['$scope','$sce',function($scope,$sce){ //... $scope.preview_data.preview.embed.htmlSafe= $sce.trustAsHtml(preview_data.preview.embed.html); }
Notethatyou'llwanttobeusing1.2.0-rc3ornewer.(Theyfixedabuginrc3thatprevented"watchers"fromworkingproperlyontrustedHTML.)
查看更多AngularJS的语法,大家可以关注:AngularJS参考手册英文版,也希望大家多多支持毛票票。