Angular2 - 如何将服务注入自定义异常处理程序
Angular2 - How do I inject a service into a custom exception handler
我有一个像这样的自定义异常处理程序,我试图在其中注入服务 (ErrorReportingService)
import { ExceptionHandler, Injectable } from '@angular/core';
import {ErrorReportingService } from '../services/ErrorReportingService';
@Injectable()
export class InsightsExceptionHandler extends ExceptionHandler {
constructor(private _errorReporter: ErrorReportingService) {
super(null, null);
}
call(error, stackTrace = null, reason = null) {
this._errorReporter.logError(error);
}
}
我尝试注入的服务如下所示
import { Http, Response } from '@angular/http';
import { Injectable, Inject } from '@angular/core';
@Injectable()
export class ErrorReportingService {
private ErrorReportingUrl = `/property/insights/api/errorreporting`;
constructor(private _http: Http) { }
logError(error: any) {
var body = JSON.stringify(error);
this._http.post(this.ErrorReportingUrl, body, null);
}
}
ErrorReportingService 在应用程序组件的提供程序下注册。
我也试过像这样以不同的方式注入服务:
export class InsightsExceptionHandler extends ExceptionHandler {
private _errorReporter: ErrorReportingService;
constructor( @Inject(ErrorReportingService) errorReporter: ErrorReportingService) {
super(null, null);
this._errorReporter = errorReporter;
}
......
我在尝试 运行 应用程序时遇到此错误:
Error: (SystemJS) EXCEPTION: Error during instantiation of ApplicationRef_! (ApplicationRef -> ApplicationRef_).
ORIGINAL EXCEPTION: No provider for ErrorReportingService! (ExceptionHandler -> ErrorReportingService)
ORIGINAL STACKTRACE:
Error: DI Exception
我想在您 bootstrapping 您的应用程序的应用程序主文件中,您必须使用类似于下面的内容来处理异常,
在 bootstrap 提供商本身中添加您需要的所有服务,
bootstrap(
<YourAppComponent>,
[
// inject all the services which you need here
// so that they can be injected wherever required
ErrorReportingService,
provide(ExceptionHandler, {
useClass: InsightsExceptionHandler
})
]).catch(err => console.error(err));
打破循环使用
@Injectable()
export class ErrorReportingService {
constructor(injector:Injector) {
setTimeout(() {
this.appRef = injector.get(ApplicationRef);
});
}
}
我不知道这是否正是导致循环的原因,因为您的问题不包含 ErrorReportingService
来源,但您应该明白了。
我有一个像这样的自定义异常处理程序,我试图在其中注入服务 (ErrorReportingService)
import { ExceptionHandler, Injectable } from '@angular/core';
import {ErrorReportingService } from '../services/ErrorReportingService';
@Injectable()
export class InsightsExceptionHandler extends ExceptionHandler {
constructor(private _errorReporter: ErrorReportingService) {
super(null, null);
}
call(error, stackTrace = null, reason = null) {
this._errorReporter.logError(error);
}
}
我尝试注入的服务如下所示
import { Http, Response } from '@angular/http';
import { Injectable, Inject } from '@angular/core';
@Injectable()
export class ErrorReportingService {
private ErrorReportingUrl = `/property/insights/api/errorreporting`;
constructor(private _http: Http) { }
logError(error: any) {
var body = JSON.stringify(error);
this._http.post(this.ErrorReportingUrl, body, null);
}
}
ErrorReportingService 在应用程序组件的提供程序下注册。
我也试过像这样以不同的方式注入服务:
export class InsightsExceptionHandler extends ExceptionHandler {
private _errorReporter: ErrorReportingService;
constructor( @Inject(ErrorReportingService) errorReporter: ErrorReportingService) {
super(null, null);
this._errorReporter = errorReporter;
}
......
我在尝试 运行 应用程序时遇到此错误:
Error: (SystemJS) EXCEPTION: Error during instantiation of ApplicationRef_! (ApplicationRef -> ApplicationRef_).
ORIGINAL EXCEPTION: No provider for ErrorReportingService! (ExceptionHandler -> ErrorReportingService)
ORIGINAL STACKTRACE:
Error: DI Exception
我想在您 bootstrapping 您的应用程序的应用程序主文件中,您必须使用类似于下面的内容来处理异常,
在 bootstrap 提供商本身中添加您需要的所有服务,
bootstrap(
<YourAppComponent>,
[
// inject all the services which you need here
// so that they can be injected wherever required
ErrorReportingService,
provide(ExceptionHandler, {
useClass: InsightsExceptionHandler
})
]).catch(err => console.error(err));
打破循环使用
@Injectable()
export class ErrorReportingService {
constructor(injector:Injector) {
setTimeout(() {
this.appRef = injector.get(ApplicationRef);
});
}
}
我不知道这是否正是导致循环的原因,因为您的问题不包含 ErrorReportingService
来源,但您应该明白了。