Sci*_*ion 14 error-handling angular
我有以下代码:
app.module.ts:
NgModule({
declarations: [
AppComponent
],
imports: [
RouterModule,
BrowserModule,
ReactiveFormsModule,
FormsModule,
HttpModule,
AppRoutingModule // Routes
],
providers: [ // services
AppLog,
{provide: ErrorHandler, useClass: MyErrorHandler}
],
bootstrap: [AppComponent]
})
export class AppModule {}
Run Code Online (Sandbox Code Playgroud)
MyErrorHandler.ts:
@Injectable()
export class MyErrorHandler implements ErrorHandler {
constructor (private _appLog: AppLog) {}
handleError(error:any):void {
let errorMessage: string = "" + error
this._appLog.logMessageAsJson(errorMessage, "error")
.subscribe(
...
)
}
}
Run Code Online (Sandbox Code Playgroud)
appLog.ts
@Injectable()
export class AppLog {
constructor (private _http: Http) {}
logMessageAsJson(message: string, type: string) {
let headers = new Headers({ "Content-Type": "application/json" })
let jsonMessage = {"type": type, "message": message}
return this._http.post(JSON.stringify(jsonMessage), headers)
}
}
Run Code Online (Sandbox Code Playgroud)
但是,当我的应用程序引导时,如果我注入MyErrorHandler
了以下错误,则会失败:
Unhandled Promise rejection: Provider parse errors:
Cannot instantiate cyclic dependency!
Run Code Online (Sandbox Code Playgroud)
如果我删除constructor (private _appLog: AppLog) {}
然后在handleError
其中执行其他操作就可以正常工作并调用ErrorHandler.
我想这不起作用,因为AppLog和MyErrorHandler同时被实例化
Gün*_*uer 11
您可以使用此变通方法来分解与DI的循环依赖关系
@Injectable()
export class MyErrorHandler implements ErrorHandler {
private _appLog: AppLog;
constructor (injector:Injector) {
setTimeout(() => this._appLog = injector.get(AppLog));
}
...
}
Run Code Online (Sandbox Code Playgroud)
Angulars DI本身不支持循环依赖.
ErrorHandler 在提供者之前创建。所以我们需要 Injector 在我们的自定义错误处理程序类中进行依赖注入。
@Injectable()
export class MyErrorHandler implements ErrorHandler{
constructor(private injector: Injector) { }
handleError(error: any) {
let router = this.injector.get(ServiceName);
}
}
Run Code Online (Sandbox Code Playgroud)
通过 Angular cli 创建一个默认服务并查看第一部分 providedIn: 'root',
@Injectable({
providedIn: 'root',
})
export class CustomService{
constructor(private otherService: OtherService) { // ok not failed }
}
Run Code Online (Sandbox Code Playgroud)
有关更多详细信息,请检查角度 @Injectable-level configuration
@NgModule 级别的注入器您可以使用非根 NgModule 的提供程序元数据选项在模块级别配置提供程序,以将提供程序的范围限制为该模块。这相当于在 @Injectable() 元数据中指定非根模块,除了通过提供者提供的服务不可摇树。
归档时间: |
|
查看次数: |
3473 次 |
最近记录: |