由于版本不同,可能有些问题在某些版本下出现,某些版本下不出现.

指令不可平行(v1.3.2):

多个指令不能这样一个接着一个排下去:

  1. <div>
  2. <directive-one/>
  3. <directive-two/>
  4. <directive-three/>
  5. </div>

这样会导致的结果就是,只能读取<directive-one/>,后面的两个指令被自动无视掉~~~凭空消失鸟~~~

解决办法: 每个指令放在一个div里

  1. <div>
  2. <directive-one/>
  3. </div>
  4. <div>
  5. <directive-two/>
  6. </div>
  7. <div>
  8. <directive-three/>
  9. </div>

还有个解决办法,把指令的restrict指定为EA,然后不要使用<directive/>这种形式,而是使用<div directive>这种形式.

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

变量名和模块名不能相同(v1.3.2):

如下这样会报错,无法执行:

  1. var model = angular.module('model',[]);

玫红色和墨绿色的两个名字不能相同,这个问题很少出现,应该是不会的.但是有一次确实遇到了...

解决办法: 不说了...

指令模板里面不能用出现指令名作为类名(v1.3.2):

比如一个指令叫 <menu-bar/>

那么,指令的模板里面,我不能再有 <div class="menu-bar">

如果遇到这种情况,它会报错: $compile:multidir

解决办法:

1.换不同的名字

2.指令的restrict中去掉C值

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

e.stopPropagation()阻止不了a链接的默认跳转事件(v1.3.2): 

比如这样一段代码:

  1. <a href="http://www.baidu.com">
  2. <span ng-click="do($event)"></span>
  3. </a>
  1. $scope.do = function(e){
  2. e.stopPropagation();
  3. }

这里我已经给do函数添加了阻止冒泡,但是a链接的跳转还是会触发的.

解决办法: 使用 e.preventDefault();

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

通过link函数中的iele来给元素绑定事件和通过ng-click(ng-...)等绑定事件的差异性(v1.3.2): 

这个其实不是坑,只是使用上的一个注意点.什么意思呢?

就是说,指令的link属性第二个参数'iele',有时候我们可以通过$(iele).bind(),直接使用jq来给元素绑定事件:

  1. link: function(scope,iele){
  2. $(iele).find('input').bind('focus',function(){
  3. scope.flag = true
  4. })
  5. }

另外,我们也可以在html中使用 ng-click(ng-event...)等来绑定事件:

  1. <input ng-focus="changeFlag()">
  1. link: function(scope,iele){
  2. scope.changeFlag = function(){
  3. scope.flag = true
  4. }
  5. }

那么什么时候使用第一种,什么时候使用第二种呢?

是这样的,如果事件处理程序里,改变了当前scope下的属性值,也就是说,数据发生了改变,这个时候使用第二种,如果事件处理程序里,仅仅改变视图的显示(并非通过数据的改变来改变视图的显示),这个时候使用第一种.

为什么呢? 因为使用第二种,是ng自己绑定的事件,在执行事件以后,ng会自动进行脏值检测($digest),而自己绑定的事件,ng是不会检测的(虽然我做的过程中发现有时候也会检测...⊙﹏⊙b汗),这样,scope下数据模型发生改变,是不会被检测到的,需要手动去调用$digest,虽然也可以实现,但是就不符合ng的设计模式了.

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

给指令添加控制器时候的scope问题(v1.3.2):

这个坑很大...一不小心陷入万丈深渊...

比如有一个指令:

  1. <directive/>

指令是这样定义的:

  1. module.directive('directive',function(){
  2. return {
  3. restrict:'E',
  4. replace:true,
  5. templateUrl:'index.html'
  6. }
  7. })

然后index.html是这样的:

  1. <div ng-controller="controllerOne">
  2. ...
  3. </div>

定义控制器:

  1. module.controller('controllOne',function($scope){
  2. $scope.a = 'a'
  3. })

这样,正常的理解就是directive指令这个div,使用controllerOne来管理,它的scope就是controllerOne里面的$scope.

但是事实不是这样的,用这种方式定义的controller,$scope并非是一个单独的继承了父scope的scope,而是直接绑定在了根scope上!

解决办法: 在指令元素上绑定ng-controller属性,而不是指令的html模板上:

  1. <directive ng-controller="controllerOne"/>

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

使用ui-router路由切换时状态的事件(ui-router.min.js  v0.2.12)

ui-router状态改变时会触发$stateChangeStart,$stateChangeSuccess,$viewContentLoading,$viewContentLoaded这些事件,但是这些事件不能绑定在状态的controller属性的控制器里:

  1. $stateProvider.state('index',{
  2. url:'/index',
  3. resolve:{
  4. rsv:'aService'
  5. },
  6. controller:function($rootScope,$scope,rsv){
  7. $scope.username = rsv.getName();
  8. $rootScope.$on('$viewContentLoading',function(event, viewConfig){
  9. alert('视图开始渲染');
  10. });
  11. $rootScope.$on('$viewContentLoaded',function(){
  12. alert('视图渲染完毕');
  13. })
  14. },
  15. templateUrl:'./tpls/login.html'
  16. });

这样做,每次进入index状态,都会实例化一个控制器,都会绑定一次事件,这样,$viewContentLoading和$viewContentLoaded事件会越来越多.

解决办法: 在外层的控制器的$rootScope里绑定事件.

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

date过滤器:

使用date过滤器过滤时间时,时间的值如果是数字或者字符串数字,这个数字不是时间戳,而是当前时间毫秒数.也就是时间戳*1000

---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 

使用ui-router路由的$urlRouterProvider无效(ui-router.min.js  v0.2.12)

定义了一个路由,然后通过$urlRouteProvider来定义一个重定向: 当匹配到'/'的时候,重定向到'/all'

  1. flightApp.config(function($stateProvider,$locationProvider,$urlRouterProvider){
  2. $locationProvider.html5Mode(true).hashPrefix('!');
  3.  
  4. $stateProvider.state('index',{
  5. url:'/:date',
  6. templateUrl:'tpls/flights.html',
  7. resolve:{
  8. 'filterFlights':function($http,$stateParams){
  9. return $http({
  10. method:'get',
  11. url:'cache/flights_'+($stateParams.date || 'all')+'.json'
  12. });
  13. }
  14. },
  15. controller: 'fligntsControll'
  16. });
  17.  
  18. $urlRouterProvider.when('/','/all');
  1. });

但是这个重定向并没有实现,也没有任何报错.原因不详.

解决办法:修改顺序,把$urlRouterProvider.when()这段代码移到$stateProvider.state()之前

  1. flightApp.config(function($stateProvider,$locationProvider,$urlRouterProvider){
  2. $locationProvider.html5Mode(true).hashPrefix('!');
  3.  
  4. $urlRouterProvider.when('/','/all');
  5.  
  6. $stateProvider.state('index',{
  7. url:'/:date',
  8. templateUrl:'tpls/flights.html',
  9. resolve:{
  10. 'filterFlights':function($http,$stateParams){
  11. return $http({
  12. method:'get',
  13. url:'cache/flights_'+($stateParams.date || 'all')+'.json'
  14. });
  15. }
  16. },
  17. controller: 'fligntsControll'
  18. });
  19. });

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

angular常见坑洞的更多相关文章

  1. 常见开发需求之angular上拉加载更多

    需求   移动端使用angular实现上拉加载更多的条目,这个需求比较常见,网上的插件改动起来比较麻烦,不如自己写一个最适合,以前有同事写了一个,奈何bug太多,后来改分页了,我们产品说什么都让做,没 ...

  2. 常见的几个angular.js的问题

    来源于网络收集 一.ng-show/ng-hide 与 ng-if的区别? 我们都知道ng-show/ng-hide实际上是通过display来进行隐藏和显示的.而ng-if实际上控制dom节点的增删 ...

  3. Atitit.angular.js 使用最佳实践 原理与常见问题解决与列表显示案例 attilax总结

    Atitit.angular.js 使用最佳实践 原理与常见问题解决与列表显示案例 attilax总结 1. 本文范围 1 2. Angular的优点 1 2.1. 双向数据绑定 1 2.2. dsl ...

  4. C++常见错误坑洞

    指针没初始化就使用*解引用运算符; 连续delete释放new指针; 使用delete 是否常规普通变量内存; 地址直接复制给制作

  5. Angular移除不必要的$watch之性能优化

    双向绑定是Angular的核心概念之一,它给我们带来了思维方式的转变:不再是DOM驱动,而是以Model为核心,在View中写上声明式标签.然后,Angular就会在后台默默的同步View的变化到Mo ...

  6. 自定义Angular插件 - 网站用户引导

    最近由于项目进行了较大的改版,为了让用户能够适应这次新的改版,因此在系统中引入了“用户引导”功能,对于初次进入系统的用户一些简单的使用培训training.对于大多数网站来说,这是一个很常见的功能.所 ...

  7. Angular Service入门

    1.Angular内置service Angular为了方便开发者开发,本身提供了非常多的内置服务.可以通过https://docs.angularjs.org/api/ng/service查看Ang ...

  8. Angular 基础入门

    简介 什么是AngularJS 一个功能非常完备的前端框架,通过增强HTML的方式提供一种便捷开发Web应用程序的方式 其核心特点就是几乎无任何DOM操作,让开发人员的精力和时间全部集中于业务 MVC ...

  9. angular学习笔记(二十九)-$q服务

    angular中的$q是用来处理异步的(主要当然是http交互啦~). $q采用的是promise式的异步编程.什么是promise异步编程呢? 异步编程最重要的核心就是回调,因为有回调函数,所以才构 ...

随机推荐

  1. WampServer搭建php环境可能遇到的问题

    WampServer搭建php环境可能遇到的问题 1.安装时报错,缺少 MSVCR100.dll 文件 这是因为wampServer安装时用到的vc库没有更新,要安装更新之后再进行安装,因为之前安装的 ...

  2. TreeView递归绑定无限分类数据

    TreeView递归绑定无限分类数据 实现一个动态绑定,无限级分类数据时,需要将数据绑定到TreeView控件,分类表的结构是这样的: 字段 类型 Id int ParentId int Name N ...

  3. CSS3选择器(一)

    E[att^='val'] 选择属性值以val开头的任何字符 E[att$='val'] 选择属性值以val结尾的任何字符 E[att*='val'] 选择属性值包含val的任何字符 :root HT ...

  4. ABAP:SAP报表性能的优化

    大部分ABAPer都是从SAP报表及打印开始学起的,大家也都认为写个SAP报表程序是最简单不过的事了. 但是实际情况真的如此吗?写报表时除了保证数据的准确性,您可曾考虑过报表的性能问题吗? 由于报表程 ...

  5. Bonobo Git Server (Simple git server for Windows.) 测试备忘

    Bonobo Git Server是一款Windows上的Git Server,它使用IIS即可,走的是Http协议,只要简单的安装就能使用,但是因为我的项目大小有1.35GB在 push 的时候一直 ...

  6. 关于Fragment 不响应onActivityResult的情况分析 (

    大家都知道,可以通过使用 startActivityForResult() 和 onActivityResult() 方法来传递或接收参数. 但你是否遭遇过onActivityResult()不执行或 ...

  7. Ubuntu14.04下安装Hadoop2.5.1 (单机模式)

    本文地址:http://www.cnblogs.com/archimedes/p/hadoop-standalone-mode.html,转载请注明源地址. 欢迎关注我的个人博客:www.wuyudo ...

  8. JAVA基础学习day19--IO流一、FileWrite与FileReader

    一.IO简述 1.1.简述 IO:input/output IO流用来处理设备之间的数据传输 Java对数据的操作是通过流的方式 Java用于操作流的对象都在IO包中. 1.2.结构 字节流抽象类: ...

  9. qsort

    /*** *qsort.c - quicksort algorithm; qsort() library function for sorting arrays * Copyright (c) Mic ...

  10. oracle中replace、length、lengthb、substr、substrb函数

    1.replacereplace(x,y,z)返回值为将字符串X中的Y串用Z串替换后的结果字符串. replace(x,y)返回值将字符串X中为Y串的地方删除例:epacel('aaabbb','bb ...