[angularjs之我见]注入器

刚开始看angularjs时,总是云里雾里的,出现了很多新的理念。最后硬着头皮看源码,还真发现许多奇妙处,记录下来:

注入器Injector

?

anguarjs的注入器主要是用来将provider作为参数注入到被注入的函数中。

其包合:

1.invoke(fn, self, locals):通过fn的参数列表(获取[]方式指定,或$inject)得到需要注入的provider作为fn的参数调用fn。

注:如果提供了locals,系统会先通过locals查找注入列表,只有找不到时,才找provider

?

args.push(
        locals && locals.hasOwnProperty(key)
           ? locals[key]: getService(key)
);

?2.annotate(fn),获得注入列表

?

有三种方式:

A.通过推测来注释:通过函数参数推断

B.显式注释:在函数中指定$inject

C.内联注释:通过数组方式,最后一个元素为函数

?

3.instantiate(Type, locals):通过Type创建一个实力化对象,Type函数默认支持DI

其实他的原理是通过Type创建对象,再通过invoke函数实现DI,此时第二个参数self为创创建的对象。

?

4.get(serviceName):调用getService,根据serviceName获取provider,此时很重要的是provider的cache,和获取的方式。

有两种注入器,一种是ProviderInjector,另外是InstanceInjector

他们的cache分别是providerCache和instanceCache

而且获取方式分别为:

?

?

function () {
    throw $injectorMinErr(‘unpr‘, "Unknown provider: {0}", path.join(‘ <- ‘));
}

和

function (servicename) {
    var provider = providerInjector.get(servicename + providerSuffix);
    return instanceInjector.invoke(provider.$get, provider);
}

?从上可以看出,providerCache一定存在指定的provider,否则会报错。

InstanceInjector获取时,会先从providerCache中获得provider,再通过instanceInjector的invoke,对获得的provider的$get函数做DI,所以这就是为何provider必须体供$get的函数的原因。

?

?

那DI是什么时间发生的呢?

1.在module的config中

module中的config ==>providerCache中的$injector的invoke,

此时$injector为providerInjector,所以config函数注入的将是providerCache中的Provider.

?

2.在module的runBlocks中

?

此时调用的是instanceInjector的invoke,所以被注入的都是instanceCache的Provider

?

以下是module体供的方法:

provider?==>providerCache中的$provide的provider,

factory ==>providerCache中的$provide的factory,

service ==>providerCache中的$provide的service,

value ==>providerCache中的$provide的value,

constant ==>providerCache中的$provide的constant

?

?

?

?

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。