我在改别人代码时,遇到下面一段:
这段代码传递给controller一个字符串"HomeCtrl"
和一个数组
["$rootScope", "$http",```````,"thirdpartyService", function(a, b, ,,,,){}]
那么这个function中的参数 a,b,c等,就对应着前面的 $rootScope
$http
么?
我在angular的api文档只找到这样的介绍,关于controller:
我在改别人代码时,遇到下面一段:
这段代码传递给controller一个字符串"HomeCtrl"
和一个数组
["$rootScope", "$http",```````,"thirdpartyService", function(a, b, ,,,,){}]
那么这个function中的参数 a,b,c等,就对应着前面的 $rootScope
$http
么?
我在angular的api文档只找到这样的介绍,关于controller:
对的,是一一对应的,在依赖注入时把参数取出来做了处理的
源码里有说明的demo,可以看一下
filter、controller、directive等等都和invokeLater有关
通过invokeLater可以返回一个闭包,当调用config,provider(即moduleInstance返回的那些api)调用时,实质上就是调用这个闭包,将其存入invokeQueue中。注意此处只是入队操作,并未执行。执行有个runinvokequeue方法,* invoke,通过annoate取出依赖注入,将依赖注入为参数调用函数体
建议了解一下angularjs的启动流程http://www.cnblogs.com/wuya16/p/3769032.html
10 回答11.1k 阅读
6 回答3k 阅读
5 回答4.8k 阅读✓ 已解决
4 回答3.1k 阅读✓ 已解决
2 回答2.6k 阅读✓ 已解决
3 回答2.3k 阅读✓ 已解决
3 回答2.1k 阅读✓ 已解决
这里是依赖注入的写法,因为参数名称是不能够随意更改的,但是我们会遇到要代码压缩的情况,这样参数的名称就会改变。所以
ng
就用这种写法来解决参数名称改变也不会影响程序运行的做法。扩展阅读:
理解JavaScript中的依赖注入