例子:
import { Injectable } from '@angular/core';
let count = 0;
@Injectable()
export class MyService {
seed: number;
_count: number;
constructor(){
this.seed = Number((Math.random() * 100).toFixed(0));
this._count = count++;
console.log('diablo constructor called: ' + this.seed);
}
}
data:image/s3,"s3://crabby-images/42b30/42b301779fe236c6d6c7957798151eaa9f585a11" alt=""
Service构造函数的断点只触发了一次:
data:image/s3,"s3://crabby-images/08bed/08bed8361e8c6cc97949fc57d1b57d7f738550bd" alt=""
data:image/s3,"s3://crabby-images/3abe2/3abe20979f4bc58bbee7633295ba7fb72df1bd90" alt=""
这个单例行为在Angular DI帮助文档里有提到:
https://angular.io/guide/glossary#injector
data:image/s3,"s3://crabby-images/bce96/bce961c732453fb6501c488e6f02b636a10bfb58" alt=""
data:image/s3,"s3://crabby-images/2967b/2967bff027940071db444f60c14f2fffbeea64fb" alt=""
什么时候会失去单例的特性呢?看这个例子:
import { Injectable } from '@angular/core';
@Injectable()
export class MyService {
seed: number;
constructor(){
this.seed = Number((Math.random() * 100).toFixed(0));
console.log('diablo constructor called: ' + this.seed);
}
}
@Injectable()
export class MyNewService {
seed: number;
text: 'NewService';
constructor(){
this.seed = Number((Math.random() * 100).toFixed(0));
console.log('diablo constructor called: ' + this.seed);
}
}
NgModule里的定义:
data:image/s3,"s3://crabby-images/74f1c/74f1c90aeeb683db22b2145901a05edeb14c5f57" alt=""
表面上看,请求MyService时,也使用MyNewService进行类的实例化,似乎我们会得到MyNewService的单例。
constructor(old: MyService, newS: MyService) {
this.test();
console.log('ok');
}
其实不然,测试发现:我们得到了两个不同的MyNewService实例:
data:image/s3,"s3://crabby-images/9fe38/9fe3854e3203ababe32de2475307095cc2aa0244" alt=""
根据token(MyService)拿到factory(MyNewService_Factory):
data:image/s3,"s3://crabby-images/1b2d1/1b2d1187524c4d592eb9918f34afb54cc3cbfc6c" alt=""
第二次触发,token变成了MyNewService:
data:image/s3,"s3://crabby-images/d7f26/d7f26eec0c034d1012ef656803874b8e9bc6c386" alt=""
用了useExisting之后的效果:
data:image/s3,"s3://crabby-images/ede02/ede028d197668b3a1d9ed166ef1adee448795c04" alt=""
网友评论