angularJS依赖注入时候的顺序问题

遇到问题

刚开始接触angularJS也就三个月,这期间大量的工做都是频繁的编码、调试和继续编码。这期间也没有遇到过什么大问题,angularJS这货也是学的稀里糊涂的。
这两天却是发现一个问题,我须要一个上传文件功能,使用了 angular-file-upload 这个module。按照文档里的例子写入依赖注入前端

angular.module('myapp', ['mapDir', 'mapsrv', 'angularFileUpload']) .controller("MapsCtrl", ["$scope", "$http", "$rootScope", '$upload', "lmapsrv", function($scope, $http, $rootScope, $location, lmapsrv,$upload) { ………………………… }) ])
那两个map有关的是我本身的module,其中一个是directive,$upload是上传文件有关的。我遇到的问题是在调试代码的时候老是$upload为null,用到这的时候老是报错。检查依赖和文件都没用错,引用也没发现有什么特别的问题。昨天发现这个问题以后由于忙着其余事情,暂时搁置上传文件这个功能。当时以为这真奇怪。python

解决问题

今天终于腾出手了想这个事情了,先考虑的是否是angularJS版本不同了(好笑),之前用的1.2.6,如今用的1.2.18。可是换过版本仍是问题依旧,最后只有一招了,打断点看堆栈和变量。不打没关系,一打还真看出问题了。发现一个奇怪的现象,明明已经执行过了'angularFileUpload'相关的代码,可是$upload变量雷打不动的仍是null。真是百思不得其解。在测试寻找问题根源的过程当中,无心间将 "$http", "$rootScope"两个依赖的位置调换了,忽然发现个人$http.get()开始报错了,这时候断点看见的变量更是奇怪$http在firebug里出现的竟然是$$ 的结构。忽然才明白过来
.controller("MapsCtrl", ["$scope", "$http", "$rootScope", '$upload', "lmapsrv", function($scope, $http, $rootScope, $location, lmapsrv,$upload) {}])
上面中括号里面的依赖和function的参数列表是顺序对应的关系
正确的顺序是以下的:
.controller("MapsCtrl", ["$scope", "$http", "$rootScope", '$upload', "lmapsrv", function($scope, $http, $rootScope, lmapsrv,$upload, **$location**) {}])git

问题出现的缘由

问题出现的缘由仍是对angularJS不了解,不知道注入依赖还有顺序的问题。以前没有暴露这个问题应该是我每次添加新的module的时候都是在尾部添加,而此次本身写的module,并且随意放置位置了,才致使这个我问题的出现。不过有了此次问题,却是长进了很多!我这里还潜藏了一个问题,function的最后一个参数也会是空值,原则上应该是我不用就不要写进来。这时候,感受angularJS真的是颇有意思的东西,我这个写python后台应用的,用bootstrap看看参考就能搞一对对漂亮的界面出来,伪前端装逼也没人发现。github

相关文章
相关标签/搜索