我正在尝试实现一个将用户重定向到错误页面的ExceptionHandler。
为此,我需要像这样注入路由器对象:
@Injectable()
class RedirectExceptionHandler extends ExceptionHandler {
constructor(private router: Router) {
super(null, null);
}
call(error: any, stackTrace: any = null, reason: any = null) {
// ...log and redirect to error page
}
}
然而,当我运行此代码时,我得到一个例外:
(index):87 Error: EXCEPTION: Error during instantiation of ApplicationRef_! (ApplicationRef -> ApplicationRef_).
ORIGINAL EXCEPTION: Cannot instantiate cyclic dependency! (ExceptionHandler -> Router -> ApplicationRef)
ORIGINAL STACKTRACE:
Error: DI Exception
at CyclicDependencyError.BaseException [as constructor] (http://localhost:1080/node_modules/@angular/core/src/facade/exceptions.js:17:23)
at CyclicDependencyError.AbstractProviderError[as constructor] (http://localhost:1080/node_modules/@angular/core/src/di/reflective_exceptions.js:39:16)
at new CyclicDependencyError(http://localhost:1080/node_modules/@angular/core/src/di/reflective_exceptions.js:102:16)
at ReflectiveInjector_._new (http://localhost:1080/node_modules/@angular/core/src/di/reflective_injector.js:613:19)
at ReflectiveInjectorDynamicStrategy.getObjByKeyId (http://localhost:1080/node_modules/@angular/core/src/di/reflective_injector.js:270:50)
at ReflectiveInjector_._getByKeyDefault (http://localhost:1080/node_modules/@angular/core/src/di/reflective_injector.js:795:38)
at ReflectiveInjector_._getByKey (http://localhost:1080/node_modules/@angular/core/src/di/reflective_injector.js:767:25)
at ReflectiveInjector_._getByReflectiveDependency (http://localhost:1080/node_modules/@angular/core/src/di/reflective_injector.js:757:21)
at ReflectiveInjector_._instantiate (http://localhost:1080/node_modules/@angular/core/src/di/reflective_injector.js:654:36)
at ReflectiveInjector_._instantiateProvider (http://localhost:1080/node_modules/@angular/core/src/di/reflective_injector.js:626:25)
Evaluating http://localhost:1080/app/main.js
Error loading http://localhost:1080/app/main.js
有解决方案吗?是否可以在调用方法中实例化路由器,从而避免在对象创建过程中出现循环依赖?
答案 0 :(得分:0)
在已经实例化错误处理程序组件之后,注入Angular的注入器并在稍后阶段获取路由器实例:
constructor(private injector:Injector) {
super(null);
}
ngOnInit() {
this.router = this.injector.get(Router);
}
稍后您可以使用路由器实例:
call(exception:any, stackTrace?:any, reason?:string):void {
this.router.navigate(...);
}