Angular에서 오류를 처리하는 방법을 이해하는 기사 1개
Angular에서 오류를 어떻게 처리할 수 있나요? 이 기사에서는 Angular의 오류 처리 메커니즘을 안내하고 오류를 처리하는 방법을 소개합니다.
오류 처리는 코드를 작성할 때 자주 발생하고 처리해야 하는 요구 사항입니다. 예외 처리 논리는 프로그램 충돌을 방지하기 위한 것입니다. Angular
가 처리하는 방법을 살펴보겠습니다. 오류. [관련 튜토리얼 추천: "Angular
处理错误的方式。【相关教程推荐:《angular教程》】
什么是Angular
Angualr
是一款来自谷歌的开源的 web 前端框架,诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。
AngularJS 是基于声明式编程模式 是用户可以基于业务逻辑进行开发. 该框架基于HTML的内容填充并做了双向数据绑定从而完成了自动数据同步机制. 最后, AngularJS 强化的DOM操作增强了可测试性.
try/catch
最熟悉的的方式,就是在代码中添加try/catch
块,在try
中发生错误,就会被捕获并且让脚本继续执行。然而,随着应用程序规模的扩大,这种方式将变得无法管理。
ErrorHandler
Angular
提供了一个默认的ErrorHandler
,可以将错误消息打印到控制台,因此可以拦截这个默认行为来添加自定义的处理逻辑,下面尝试编写错误处理类:
import { ErrorHandler, Injectable } from "@angular/core"; import { HttpErrorResponse } from "@angular/common/http"; @Injectable() export class ErrorsHandler implements ErrorHandler { handleError(error: Error | HttpErrorResponse) { if (!navigator.onLine) { console.error("Browser Offline!"); } else { if (error instanceof HttpErrorResponse) { if (!navigator.onLine) { console.error("Browser Offline!"); } else { // Handle Http Error (4xx, 5xx, ect.) console.error("Http Error!"); } } else { // Handle Client Error (Angular Error, ReferenceError...) console.error("Client Error!"); } console.error(error); } } }
通常在
app
下创建一个共享目录shared
,并将此文件放在providers
文件夹中
现在,需要更改应用程序的默认行为,以使用我们自定义的类而不是ErrorHandler
。修改app.module.ts
文件,从@angular/core
导入ErrorHandler
,并将providers
添加到@NgModule
模块,代码如下:
import { NgModule, ErrorHandler } from "@angular/core"; import { BrowserModule } from "@angular/platform-browser"; import { FormsModule } from "@angular/forms"; // Providers import { ErrorsHandler } from "./shared/providers/error-handler"; import { AppComponent } from "./app.component"; @NgModule({ imports: [BrowserModule, FormsModule], declarations: [AppComponent], providers: [{ provide: ErrorHandler, useClass: ErrorsHandler }], bootstrap: [AppComponent] }) export class AppModule {}
HttpInterceptor
HttpInterceptor
提供了一种拦截HTTP请求/响应的方法,就可以在传递它们之前处理。例如,可以在抛出错误之前重试几次HTTP请求。这样,就可以优雅地处理超时,而不必抛出错误。
还可以在抛出错误之前检查错误的状态,使用拦截器,可以检查401状态错误码,将用户重定向到登录页面。
import { Injectable } from "@angular/core"; import { HttpEvent, HttpRequest, HttpHandler, HttpInterceptor, HttpErrorResponse } from "@angular/common/http"; import { Observable, throwError } from "rxjs"; import { retry, catchError } from "rxjs/operators"; @Injectable() export class HttpsInterceptor implements HttpInterceptor { intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> { return next.handle(request).pipe( retry(1), catchError((error: HttpErrorResponse) => { if (error.status === 401) { // 跳转到登录页面 } else { return throwError(error); } }) ); } }
同样需要添加到app.module.ts
中
import { NgModule, ErrorHandler } from "@angular/core"; import { HTTP_INTERCEPTORS } from "@angular/common/http"; import { BrowserModule } from "@angular/platform-browser"; import { FormsModule } from "@angular/forms"; // Providers import { ErrorsHandler } from "./shared/providers/error-handler"; import { HttpsInterceptor } from "./shared/providers/http-interceptor"; import { AppComponent } from "./app.component"; @NgModule({ imports: [BrowserModule, FormsModule], declarations: [AppComponent], providers: [ { provide: ErrorHandler, useClass: ErrorsHandler }, { provide: HTTP_INTERCEPTORS, useClass: HttpsInterceptor, multi: true } ], bootstrap: [AppComponent] }) export class AppModule {}
多提供者用于创建可扩展服务,其中系统带有一些默认提供者,也可以注册其他提供者。默认提供程序和其他提供程序的组合将用于驱动系统的行为。
Notifications
在控制台打印错误日志对于开发者来说非常友好,但是对于用户来说则需要一种更加友好的方式来告诉这些错误何时从GUI中发生。根据错误类型,推荐两个组件:Snackbar
和Dialog
Snackbar
:推荐用于简单的提示,比如表单缺少必填字段或通知用户可预见的错误(无效电子邮件、用户名太长等)。Dialog
:当存在未知的服务器端或客户端错误时,推荐使用这种方式;通过这种方式,可以显示更多的描述,甚至call-to-action
,比如允许用户输入他们的电子邮件来跟踪错误。
在shared
文件夹中添加一个服务来处理所有通知,新建services
文件夹,创建文件:notification.service.ts
,代码如下:
import { Injectable } from "@angular/core"; import { MatSnackBar } from "@angular/material/snack-bar"; @Injectable({ providedIn: "root" }) export class NotificationService { constructor(public snackBar: MatSnackBar) {} showError(message: string) { this.snackBar.open(message, "Close", { panelClass: ["error"] }); } }
更新error-handler.ts
,添加NotificationService
:
import { ErrorHandler, Injectable, Injector } from "@angular/core"; import { HttpErrorResponse } from "@angular/common/http"; // Services import { NotificationService } from "../services/notification.service"; @Injectable() export class ErrorsHandler implements ErrorHandler { //Error handling需要先加载,使用Injector手动注入服务 constructor(private injector: Injector) {} handleError(error: Error | HttpErrorResponse) { const notifier = this.injector.get(NotificationService); if (!navigator.onLine) { //console.error("Browser Offline!"); notifier.showError("Browser Offline!"); } else { if (error instanceof HttpErrorResponse) { if (!navigator.onLine) { //console.error("Browser Offline!"); notifier.showError(error.message); } else { // Handle Http Error (4xx, 5xx, ect.) // console.error("Http Error!"); notifier.showError("Http Error: " + error.message); } } else { // Handle Client Error (Angular Error, ReferenceError...) // console.error("Client Error!"); notifier.showError(error.message); } console.error(error); } } }
如果在一个组件中抛出一个错误,可以看到一个很好的snackbar
消息:
日志和错误跟踪
当然不能期望用户向报告每个bug
,一旦部署到生产环境中,就不能看到任何控制台日志。因此就需要能够记录错误的后端服务与自定义逻辑写入数据库或使用现有的解决方案,如Rollbar
、Sentry
、Bugsnag
。
接下来创建一个简单的错误跟踪服务,创建logging.service.ts
:
import { Injectable } from "@angular/core"; import { HttpErrorResponse } from "@angular/common/http"; @Injectable({ providedIn: "root" }) export class LoggingService { constructor() {} logError(error: Error | HttpErrorResponse) { // This will be replaced with logging to either Rollbar, Sentry, Bugsnag, ect. if (error instanceof HttpErrorResponse) { console.error(error); } else { console.error(error); } } }
将服务添加到error-handler.ts
angular 튜토리얼
Angular란 무엇인가
Angualr
는 Google의 이 오픈 소스 웹 프런트엔드 프레임워크는 2009년에 탄생했습니다. Misko Hevery 등이 만들었으며 나중에 Google에 인수되었습니다. 많은 Google 제품에서 사용되어 온 뛰어난 프런트엔드 JS 프레임워크입니다. 🎜🎜AngularJS는 사용자가 비즈니스 로직을 기반으로 개발할 수 있는 선언적 프로그래밍 모델을 기반으로 합니다. 프레임워크는 HTML 콘텐츠 채우기 및 양방향 데이터 바인딩을 기반으로 하여 자동 데이터 동기화 메커니즘을 완성합니다. 향상된 테스트 가능성.🎜
try/catch
🎜가장 친숙한 방법은 < code>try/catch<를 추가하는 것입니다. /code> 블록,try
에서 오류가 발생하면 이를 포착하고 스크립트는 계속 실행됩니다. 그러나 애플리케이션의 크기가 커지면 이 접근 방식은 관리하기 어려워집니다. 🎜ErrorHandler
🎜Angular
는 오류가 발생할 수 있는 기본 ErrorHandler
를 제공합니다. 메시지가 콘솔에 인쇄되므로 이 기본 동작을 가로채서 사용자 정의 처리 논리를 추가할 수 있습니다. 아래 오류 처리 클래스를 작성해 보세요. 🎜import { ErrorHandler, Injectable, Injector } from "@angular/core"; import { HttpErrorResponse } from "@angular/common/http"; // Services import { NotificationService } from "../services/notification.service"; import { LoggingService } from "../services/logging.service"; @Injectable() export class ErrorsHandler implements ErrorHandler { //Error handling需要先加载,使用Injector手动注入服务 constructor(private injector: Injector) {} handleError(error: Error | HttpErrorResponse) { const notifier = this.injector.get(NotificationService); const logger = this.injector.get(LoggingService); if (!navigator.onLine) { //console.error("Browser Offline!"); notifier.showError("Browser Offline!"); } else { if (error instanceof HttpErrorResponse) { if (!navigator.onLine) { //console.error("Browser Offline!"); notifier.showError(error.message); } else { // Handle Http Error (4xx, 5xx, ect.) // console.error("Http Error!"); notifier.showError("Http Error: " + error.message); } } else { // Handle Client Error (Angular Error, ReferenceError...) // console.error("Client Error!"); notifier.showError(error.message); } // console.error(error); logger.logError(error); } } }
🎜일반적으로🎜이제app
shared하고 이 파일을providers
폴더에 넣습니다 🎜
ErrorHandler. <code>app.module.ts
파일을 수정하고 @angular/core
에서 ErrorHandler
를 가져온 다음 providers
를 @NgModule 모듈에서 코드는 다음과 같습니다: 🎜rrreeeHttpInterceptor
🎜HttpInterceptor
HTTP 요청/응답을 가로채서 전달하기 전에 처리하는 방법을 제공합니다. 예를 들어 오류가 발생하기 전에 HTTP 요청을 여러 번 재시도할 수 있습니다. 이렇게 하면 오류가 발생하지 않고 시간 초과를 적절하게 처리할 수 있습니다. 🎜🎜오류가 발생하기 전에 오류 상태를 확인할 수도 있습니다. 인터셉터를 사용하면 401 상태 오류 코드를 확인하고 사용자를 로그인 페이지로 리디렉션할 수 있습니다. 🎜rrreee🎜또한 app.module.ts
에 추가해야 합니다.🎜rrreee🎜확장 가능한 서비스를 생성하기 위해 여러 공급자가 사용됩니다. 시스템에는 일부 기본 공급자가 함께 제공되며 다른 공급자도 가능합니다. 누구. 기본 공급자와 다른 공급자의 조합이 시스템 동작을 구동하는 데 사용됩니다. 🎜
알림
🎜콘솔에 오류 로그를 인쇄하는 것은 개발자에게는 매우 친숙하지만 사용자에게는 그렇지 않습니다. GUI에서 이러한 오류가 발생할 때 알려주는 친숙한 방법이 필요합니다. 오류 유형에 따라 두 가지 구성 요소가 권장됩니다:Snackbar
및 Dialog
🎜- 🎜
Snackbar
: 간단한 프롬프트에 권장됩니다. 필수 필드가 누락된 양식 또는 예측 가능한 오류(잘못된 이메일, 너무 긴 사용자 이름 등)를 사용자에게 알리는 등의 작업입니다. 🎜 - 🎜
Dialog
: 이 방법은 알 수 없는 서버측 또는 클라이언트측 오류가 있을 때 권장되며, 더 많은 설명을 표시할 수 있으며까지 표시할 수 있습니다. 클릭 유도 문구
(예: 사용자가 오류를 추적하기 위해 이메일을 입력하도록 허용) 🎜
shared
폴더에 서비스를 추가하여 모든 알림을 처리하고 새 services
폴더를 생성한 후 파일을 생성합니다. notification.service.ts
의 경우 코드는 다음과 같습니다. 🎜rrreee🎜error-handler.ts
를 업데이트하고 NotificationService
를 추가합니다. 🎜rrreee🎜오류가 발생한 경우 구성 요소에 던져지면 멋진 snackbar
메시지를 볼 수 있습니다: 🎜로그 및 오류 추적
🎜Of 당연히 예상치 못한 일입니다. 사용자는 모든버그
를 보고하고 일단 프로덕션에 배포되면 콘솔 로그를 볼 수 없습니다. 따라서 오류를 기록하고 데이터베이스에 사용자 정의 논리를 작성하거나 Rollbar
, Sentry
, Bugsnag
와 같은 기존 솔루션을 사용할 수 있는 백엔드 서비스가 필요합니다. > 코드>. 🎜🎜다음으로 간단한 오류 추적 서비스를 만들고 logging.service.ts
를 만듭니다. 🎜rrreee🎜 error-handler.ts
에 서비스를 추가합니다. 🎜rrreee🎜 이 시점에서 , 전체 오류 처리 메커니즘이 도입되었으며 기본적으로 다른 프레임워크나 언어로 개발된 프로젝트를 처리하는 방식과 유사합니다. 🎜더 많은 프로그래밍 관련 지식을 보려면 프로그래밍 소개를 방문하세요! !
위 내용은 Angular에서 오류를 처리하는 방법을 이해하는 기사 1개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











미들웨어를 사용하여 Go 함수의 오류 처리 개선: 함수 호출을 가로채고 특정 논리를 실행할 수 있는 미들웨어 개념을 소개합니다. 오류 처리 논리를 사용자 정의 함수로 래핑하는 오류 처리 미들웨어를 만듭니다. 함수가 호출되기 전에 오류 처리 논리가 수행되도록 미들웨어를 사용하여 처리기 함수를 래핑합니다. 오류 유형에 따라 적절한 오류 코드를 반환합니다. 야나오브라봇

C++에서 예외 처리는 try-catch 블록을 통해 오류를 적절하게 처리합니다. 일반적인 예외 유형에는 런타임 오류, 논리 오류 및 범위를 벗어난 오류가 포함됩니다. 파일 열기 오류 처리를 예로 들면, 프로그램이 파일 열기에 실패하면 예외가 발생하고 오류 메시지를 인쇄하며 catch 블록을 통해 오류 코드를 반환하므로 프로그램을 종료하지 않고 오류를 처리합니다. 예외 처리는 오류 처리 중앙 집중화, 오류 전파 및 코드 견고성과 같은 이점을 제공합니다.

C++ 클래스 디자인의 오류 처리 및 로깅에는 다음이 포함됩니다. 예외 처리: 예외 포착 및 처리, 사용자 정의 예외 클래스를 사용하여 특정 오류 정보 제공. 오류 코드: 정수 또는 열거형을 사용하여 오류 조건을 나타내고 반환 값으로 반환합니다. 주장: 사전 및 사후 조건을 확인하고 충족되지 않으면 예외를 발생시킵니다. C++ 라이브러리 로깅: std::cerr 및 std::clog를 사용한 기본 로깅. 외부 로깅 라이브러리: 레벨 필터링 및 로그 파일 회전과 같은 고급 기능을 위해 타사 라이브러리를 통합합니다. 사용자 정의 로그 클래스: 고유한 로그 클래스를 생성하고 기본 메커니즘을 추상화하며 다양한 수준의 정보를 기록하기 위한 공통 인터페이스를 제공합니다.

PHP의 최고의 오류 처리 도구 및 라이브러리는 다음과 같습니다. 내장 메소드: set_error_handler() 및 error_get_last() 타사 툴킷: 웁스(디버깅 및 오류 형식 지정) 타사 서비스: Sentry(오류 보고 및 모니터링) 타사 라이브러리: PHP-error-handler(사용자 정의 오류 로깅 및 스택 추적) 및 Monolog(오류 로깅 핸들러)

Go 함수에서 비동기 오류 처리는 오류 채널을 사용하여 고루틴의 오류를 비동기적으로 전달합니다. 구체적인 단계는 다음과 같습니다. 오류 채널을 생성합니다. 작업을 수행하고 오류를 비동기적으로 전송하려면 고루틴을 시작하세요. 채널에서 오류를 수신하려면 select 문을 사용하세요. 오류 메시지 인쇄 또는 기록과 같은 오류를 비동기적으로 처리합니다. 이 접근 방식은 오류 처리가 호출 스레드를 차단하지 않고 실행을 취소할 수 있기 때문에 동시 코드의 성능과 확장성을 향상시킵니다.

Go의 오류 처리 모범 사례에는 오류 유형 사용, 항상 오류 반환, 오류 확인, 다중 값 반환 사용, 센티널 오류 사용, 오류 래퍼 사용이 포함됩니다. 실제 예: HTTP 요청 핸들러에서 ReadDataFromDatabase가 오류를 반환하면 500 오류 응답을 반환합니다.

Go 함수 단위 테스트에는 오류 처리를 위한 두 가지 주요 전략이 있습니다. 1. 예상 값을 확인하는 데 사용되는 오류 유형의 특정 값으로 오류를 나타냅니다. 2. 테스트 함수에 오류를 전달하기 위해 채널을 사용합니다. 이는 동시 코드를 테스트하는 데 적합합니다. 실제 사례에서는 함수가 음수 입력에 대해 0을 반환하도록 보장하기 위해 오류 값 전략이 사용됩니다.

Golang에서 오류 래퍼를 사용하면 원래 오류에 상황별 정보를 추가하여 새로운 오류를 생성할 수 있습니다. 이는 다양한 라이브러리나 구성 요소에서 발생하는 오류 유형을 통합하여 디버깅 및 오류 처리를 단순화하는 데 사용할 수 있습니다. 단계는 다음과 같습니다. error.Wrap 함수를 사용하여 원래 오류를 새 오류로 래핑합니다. 새 오류에는 원래 오류의 상황별 정보가 포함됩니다. fmt.Printf를 사용하면 래핑된 오류를 출력하여 더 많은 컨텍스트와 실행 가능성을 제공할 수 있습니다. 다양한 유형의 오류를 처리할 때 오류 유형을 통합하려면 오류.Wrap 함수를 사용하세요.
