本篇文章带大家了解一下angular中的异常处理ErrorHandler,通过例子介绍一下ErrorHandler的使用方法,希望对大家有所帮助!

ErrorHandler
ErrorHandler的默认实现将错误消息打印到console。要拦截错误处理,请编写一个自定义的异常处理器,该异常处理器将把此默认行为改成你应用所需的。【相关教程推荐:《angular教程》】
以实际开发中一个例子演示使用方式:
假如前端有提出一个新需求为前端添加全局错误处理并上报错误日志,处理如下:
1、创建错误处理的error-handler.service.ts
import { HttpClient } from '@angular/common/http';
import { ErrorHandler, Injectable } from '@angular/core';
@Injectable()
export class AppGlobalErrorhandler implements ErrorHandler {
constructor(private http:HttpClient){ }
// 当程序中出现异常时,会自动调用 handleError 钩子,可判断是客户端还是来自服务端的异常。
handleError(error) {
// 打印错处信息
console.warn("customize catch execption:" , error.stack);
// ...
// 异常处理逻辑
// ...
if(['ExpressionChangedAfterItHasBeenCheckedError'].every(item => !error.stack.includes(item))){
// 上报错误日志
this.http.post('/api/errorLog', {
url: location.href,
type: 'WEB',
error: error.stack,
message: error.toString()
}).subscribe()
}
}
}
2、在app.module.ts中添加
import { AppGlobalErrorhandler } from './service/error-handler.service';
...
providers: [
...
{ provide: ErrorHandler, useClass: GlobalErrorHandler},
...
]
3、在上面处理的是页面发生的异常,实际开发中同时也需要上报接口等的异常,当前使用的是ng-alain框架,所以在default.interceptor.ts拦截器中添加代码,具体参考:ng-alain—拦截网络请求
private handleData(
event: HttpResponse<any> | HttpErrorResponse,
data?:any
): Observable<any> {
// 判断是否为错误实例
if (event instanceof HttpErrorResponse && event.url.indexOf('api/errorLog') === -1) {
// 上报接口错误日志
this.http.post('/api/errorLog', {
url: event.url,
type: 'INTERFACE',
message: event.message,
status: event.status,
statusText: event.statusText,
param: JSON.stringify(data['body']||undefined),
body: JSON.stringify((event as any)['body'] || undefined),
error:JSON.stringify( event.error),
}).subscribe()
}
return of(event);
}
// 拦截器
intercept(
req: HttpRequest<any>,
next: HttpHandler,
){
return next.handle(newReq).pipe(
// 当请求发生错误时,使用一个管道把错误发送给错误处理器
catchError((err: HttpErrorResponse) => this.handleData(err,newReq)),
mergeMap((event: any) => {
// 允许统一对请求错误处理,这是因为一个请求若是业务上错误的情况下其HTTP请求的状态是200的情况下需要
if (event instanceof HttpResponse && event.status === 200)
return this.handleData(event);
// 若一切都正常,则后续操作
return of(event);
}),
);
}
上面第3点的写法中的不是通过自动调用handleError钩子来处理错误的,在Interceptor拦截器中只能处理HttpErrorResponse类型的错误,如果这里处理了,那么ErrorHandler将捕获不到。所以在Interceptor中,如果一定要通过handleError钩子函数来处理错误,那么就需要将HttpErrorResponse类型的错误抛出。如下:
catchError((error: HttpErrorResponse) => {
if (error.status === 401) {
// 跳到登录页或者刷新token
} else {
return throwError(error);
}
})
更多编程相关知识,请访问:编程视频!!
以上就是一起聊聊angular中的ErrorHandler的详细内容,更多请关注亿码酷站其它相关文章!
<!–
–>一起聊聊angular中的ErrorHandler
—–文章转载自PHP中文网如有侵权请联系ymkuzhan@126.com删除
转载请注明来源:一起聊聊angular中的ErrorHandler
本文永久链接地址:https://www.ymkuzhan.com/45663.html
本文永久链接地址:https://www.ymkuzhan.com/45663.html
下载声明:
本站资源如无特殊说明默认解压密码为www.ymkuzhan.com建议使用WinRAR解压; 本站资源来源于用户分享、互换、购买以及网络收集等渠道,本站不提供任何技术服务及有偿服务,资源仅提供给大家学习研究请勿作它用。 赞助本站仅为维持服务器日常运行并非购买程序及源码费用因此不提供任何技术支持,如果你喜欢该程序,请购买正版! 版权声明:
下载本站资源学习研究的默认同意本站【版权声明】若本站提供的资源侵犯到你的权益,请提交版权证明文件至邮箱ymkuzhan#126.com(将#替换为@)站长将会在三个工作日内为您删除。 免责声明:
您好,本站所有资源(包括但不限于:源码、素材、工具、字体、图像、模板等)均为用户分享、互换、购买以及网络收集而来,并未取得原始权利人授权,因此禁止一切商用行为,仅可用于个人研究学习使用。请务必于下载后24小时内彻底删除,一切因下载人使用所引起的法律相关责任,包括但不限于:侵权,索赔,法律责任,刑事责任等相关责任,全部由下载人/使用人,全部承担。以上说明,一经发布视为您已全部阅读,理解、同意以上内容,如对以上内容持有异议,请勿下载,谢谢配合!支持正版,人人有责,如不慎对您的合法权益构成侵犯,请联系我们对相应内容进行删除,谢谢!


