目次
ErrorHandler
ホームページ ウェブフロントエンド jsチュートリアル Angular の ErrorHandler について話しましょう

Angular の ErrorHandler について話しましょう

Oct 12, 2021 am 10:40 AM
angular 例外処理

この記事では、angular での例外処理 ErrorHandler を理解し、例を通して ErrorHandler の使用方法を紹介します。

Angular の 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 <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>import { AppGlobalErrorhandler } from &amp;#39;./service/error-handler.service&amp;#39;; ... providers: [ ... { provide: ErrorHandler, useClass: GlobalErrorHandler}, ... ]</pre><div class="contentsignin">ログイン後にコピー</div></div>

を .ts
に追加します。プログラムで例外が発生すると、

handleError フックが自動的に呼び出され、その例外が原因かどうかが判断されます。クライアントまたはサーバー。

3. 上記で扱っているのはページ上で発生した例外ですが、実際の開発ではインターフェースなどの例外も報告する必要があります。現在使用されているため、

default.interceptor.ts インターセプターにコードを追加します。具体的な参照: ng-alain—ネットワーク要求のインターセプト

  private handleData(
    event: HttpResponse<any> | HttpErrorResponse,
    data?:any
  ): Observable<any> {
	// 判断是否为错误实例
    if (event instanceof HttpErrorResponse && event.url.indexOf(&#39;api/errorLog&#39;) === -1) {
		// 上报接口错误日志
      this.http.post(&#39;/api/errorLog&#39;, {
        url: event.url,
        type: &#39;INTERFACE&#39;,
        message: event.message,
        status: event.status,
        statusText: event.statusText,
        param: JSON.stringify(data[&#39;body&#39;]||undefined),
        body: JSON.stringify((event as any)[&#39;body&#39;] || 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 の記述方法は自動ではありません。 callhandleError

フックはエラーの処理に使用されます。

Interceptor インターセプターでは、タイプ HttpErrorResponse のエラーのみを処理できます。ここで処理される場合、ErrorHandler はキャプチャされません。到着します。したがって、Interceptor では、handleError フック関数を通じてエラーを処理する必要がある場合、HttpErrorResponse タイプのエラーをスローする必要があります。次のとおりです:

catchError((error: HttpErrorResponse) => {
        if (error.status === 401) {
          // 跳到登录页或者刷新token
        } else {
          return throwError(error);
        }
 })
ログイン後にコピー
プログラミング関連の知識については、プログラミング ビデオをご覧ください。 !

以上がAngular の ErrorHandler について話しましょうの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

C++ 関数の例外とマルチスレッド: 同時環境でのエラー処理 C++ 関数の例外とマルチスレッド: 同時環境でのエラー処理 May 04, 2024 pm 04:42 PM

C++ での関数例外処理は、マルチスレッド環境でスレッドの安全性とデータの整合性を確保するために特に重要です。 try-catch ステートメントを使用すると、特定の種類の例外が発生したときにそれをキャッチして処理し、プログラムのクラッシュやデータの破損を防ぐことができます。

C++ 例外処理はカスタム エラー処理ルーチンをどのようにサポートしますか? C++ 例外処理はカスタム エラー処理ルーチンをどのようにサポートしますか? Jun 05, 2024 pm 12:13 PM

C++ 例外処理を使用すると、例外をスローし、try-catch ブロックを使用して例外をキャッチすることで実行時エラーを処理するカスタム エラー処理ルーチンを作成できます。 1. 例外クラスから派生したカスタム例外クラスを作成し、what() メソッドをオーバーライドします。 2. throw キーワードを使用して例外をスローし、例外のタイプを指定します。扱った。

Java 関数の再帰呼び出しと例外処理の間にはどのような関係がありますか? Java 関数の再帰呼び出しと例外処理の間にはどのような関係がありますか? May 03, 2024 pm 06:12 PM

再帰呼び出しでの例外処理: 再帰の深さの制限: スタック オーバーフローの防止。例外処理を使用する: try-catch ステートメントを使用して例外を処理します。末尾再帰の最適化: スタックのオーバーフローを回避します。

C++ ラムダ式で例外を処理するにはどうすればよいですか? C++ ラムダ式で例外を処理するにはどうすればよいですか? Jun 03, 2024 pm 03:01 PM

C++ ラムダ式の例外処理には独自のスコープがなく、デフォルトでは例外はキャッチされません。例外をキャッチするには、ラムダ式キャッチ構文を使用できます。これにより、ラムダ式がその定義スコープ内の変数をキャプチャできるようになり、try-catch ブロックで例外処理が可能になります。

C++ テクノロジにおける例外処理: マルチスレッド環境で例外を正しく処理するにはどうすればよいですか? C++ テクノロジにおける例外処理: マルチスレッド環境で例外を正しく処理するにはどうすればよいですか? May 09, 2024 pm 12:36 PM

マルチスレッド C++ では、例外処理は適時性、スレッドの安全性、明確性という原則に従います。実際には、ミューテックスまたはアトミック変数を使用することで、例外処理コードのスレッド セーフを確保できます。さらに、例外処理コードの再入性、パフォーマンス、テストを考慮して、コードがマルチスレッド環境で安全かつ効率的に実行されることを確認してください。

PHP 例外処理: 例外追跡を通じてシステムの動作を理解する PHP 例外処理: 例外追跡を通じてシステムの動作を理解する Jun 05, 2024 pm 07:57 PM

PHP 例外処理: 例外追跡を通じてシステムの動作を理解する 例外は、PHP がエラーを処理するために使用するメカニズムであり、例外は例外ハンドラーによって処理されます。例外クラス Exception は一般的な例外を表し、Throwable クラスはすべての例外を表します。 throw キーワードを使用して例外をスローし、try...catch ステートメントを使用して例外ハンドラーを定義します。実際のケースでは、例外処理を使用して、calculate() 関数によってスローされる DivisionByZeroError をキャプチャして処理し、エラー発生時にアプリケーションが適切に失敗できるようにします。

PHPで例外を効果的に処理する方法(試して、キャッチ、最後に、スロー)? PHPで例外を効果的に処理する方法(試して、キャッチ、最後に、スロー)? Apr 05, 2025 am 12:03 AM

PHPでは、Try、Catch、最後にキーワードをスローすることにより、例外処理が達成されます。 1)TRYブロックは、例外をスローする可能性のあるコードを囲みます。 2)キャッチブロックは例外を処理します。 3)最後にブロックは、コードが常に実行されることを保証します。 4)スローは、例外を手動でスローするために使用されます。これらのメカニズムは、コードの堅牢性と保守性を向上させるのに役立ちます。

C++ テクノロジにおける例外処理: 例外処理のパフォーマンスを最適化するにはどうすればよいですか? C++ テクノロジにおける例外処理: 例外処理のパフォーマンスを最適化するにはどうすればよいですか? May 09, 2024 am 10:39 AM

C++ で例外処理のパフォーマンスを最適化するには、次の 4 つの手法を実装できます。 不必要な例外スローを回避します。軽量の例外クラスを使用します。効率を優先し、必要な情報のみを含む例外クラスを設計します。コンパイラ オプションを活用して、パフォーマンスと安定性の最適なバランスを実現します。

See all articles