JavaScript でのエラーの分離

Nov 21, 2016 pm 01:52 PM

インターフェースリクエストの失敗、インターフェース内のデータの一部が欠落している、運用データが期待を満たしていない...アプリケーションがリリースされてオンラインになると、私たちはこれらのリスクに直面し始めます。

これらの問題が JavaScript エラー (null ポインター例外など) につながり、効果的に分離されないと、ページ上の白い画面や操作不能などのオンライン問題が発生する可能性があります。

ダブル 11 の準備中に、過去 1 年間にフロントエンド関連のオンラインの問題を収集しました。収集された 21 件のうち、問題の半数は「データの異常によりページ表示の例外が発生する」という理由に関連していました。

エラーの影響を特定の範囲内で切り分ける方法が特に重要です。

この記事では、私たちが試した解決策のいくつかと、遭遇した問題についてお話します。

Null Pointer Exceptionから始まる

データによって引き起こされる最も一般的な問題は、Null Pointer Exceptionです。

var result = a.b.c.d;

このようなコードは、aが動的データになると、問題が発生し始めます。

値を取得するためのgetメソッドをカプセル化すると、データが存在しない場合にはunknownが返されるため、このような問題をすぐに回避できます。

 var result = get(a, 'b.c.d'); 
 但如同我们期望大家在取值前,都先做判断一样,并不能保证所有人都这么用了,用不用全靠自觉。
if (a && a.b && a.b.c) {
        var result = a.b.c.d;
}
ログイン後にコピー

したがって、次の解決策があります:


非同期データ検証

非同期データ検証のアイデアは、データ取得後、重要なデータを検出するために使用する前にスキーマ検証を行うことです 欠落例外と型不一致の例外。

このソリューションに対応して、フェッチに基づいてフェッチチェッカー 注 1 コンポーネントをカプセル化しました。

フェッチチェッカーは、データをリクエストするときにユーザーにデータに対応するスキーマを提供するように強制します:

let schema = {
    "rule": {
      "type": "string",
    },
    "banner": {
      "type": "object",
      "required": true,
      "default": {
        "url": "https://item.taobao.com/item.htm?id=527331762117"
      }
    }
};
ログイン後にコピー

このスキーマを記述する必要があります:


各フィールドの型

フィールドが必須かどうか

いつrequired フィールドが欠落している場合、データを基にする必要がありますか? fetch-checker はデータを取得した後、必要に応じてまず一定レベルの検証を実行し、それから呼び出し元にデータを返します。このように、ユーザーが取得したデータは期待どおりのものでなければなりません。

しかし、この解決策が直面する課題は次のとおりです:

呼び出し元が完全なスキーマ記述を提供することを保証する方法。スキーマを書きたくない場合は、検証に合格するために大まかなスキーマの説明を入力できます。

スキーマを効率化する方法。つまり、バンドルサイズには大きな影響を与えず、検証機能も満たすことができます。

コードコンパイル

babel からインスピレーションを得たこのソリューションは、コンパイル段階で NPE リスクのあるコードを同等の安全なコードに変換します。以下に示すように:

var a = {};
// input
var result = a.b.c;
// output
var result = (_object2 = (_object3 = a) == null ? null : _object3.b) == null ? null : _object2.c;
ログイン後にコピー

a が空のオブジェクトの場合、コンパイルされたコードを実行すると null が返されるため、コードスローエラーや後続のプロセスのブロックが回避されます。

Babel プラグイン babel-plugin-safe-member-expression 注 2 では、上記の試みを行いました。現在、cake プロジェクトでは、enableSafeMemberExpression 設定を通じてこの機能を選択的に有効にすることができます。


このソリューションはそれに比べてアクセスコストが低く、開発者は既存のコードを調整する必要がありませんが、まだ課題があります:

開発段階の問題は簡単には明らかにされず、シナリオに対するフィードバックはありませんエラーを報告する場所。理想的な状態は、開発およびデバッグ段階でできるだけ多くの問題を明らかにし、オンラインでのエラーをできるだけ減らすことです。

隠しコードを定義するにはどうすればよいですか?現時点では、すべての a.b 呼び出しメソッドは上記のスキームに従ってコンパイルされますが、テスト プロセス中に問題は見つかりませんでしたが、隠れた危険性のあるコードのみを扱う方が安全です。

静的検証


  以 flow 为代表的静态校验工具,可以在一定程度上检测出 NPE 隐患。
type res = {
        data ?: Object
}
let name = res.data.name;
// property `name`. Propery cannot be accessed on possibly undefined value
ログイン後にコピー

上記のコードで説明したように、ユーザーはまずデータが null であることが許可されているかどうかを明確にする必要があります。データが null であることが許可されている場合は、data.name のような呼び出しを通じて検出されます。これによりエラーが検出されます。

ただし、すべての企業が静的検証にアクセスできるように促進する方法や、アクセス後に開発者がすべてのタイプを記述していることを確認する方法も困難です。


上記は JavaScript でのエラー分離の内容です。さらに関連する内容については、PHP 中国語 Web サイト (www.php.cn) に注目してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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)

WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法 WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法 Dec 17, 2023 pm 02:54 PM

WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法 はじめに: 技術の継続的な発展により、音声認識技術は人工知能の分野の重要な部分になりました。 WebSocket と JavaScript をベースとしたオンライン音声認識システムは、低遅延、リアルタイム、クロスプラットフォームという特徴があり、広く使用されるソリューションとなっています。この記事では、WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法を紹介します。

WebSocket と JavaScript: リアルタイム監視システムを実装するための主要テクノロジー WebSocket と JavaScript: リアルタイム監視システムを実装するための主要テクノロジー Dec 17, 2023 pm 05:30 PM

WebSocketとJavaScript:リアルタイム監視システムを実現するためのキーテクノロジー はじめに: インターネット技術の急速な発展に伴い、リアルタイム監視システムは様々な分野で広く利用されています。リアルタイム監視を実現するための重要なテクノロジーの 1 つは、WebSocket と JavaScript の組み合わせです。この記事では、リアルタイム監視システムにおける WebSocket と JavaScript のアプリケーションを紹介し、コード例を示し、その実装原理を詳しく説明します。 1.WebSocketテクノロジー

WebSocketとJavaScriptを使ったオンライン予約システムの実装方法 WebSocketとJavaScriptを使ったオンライン予約システムの実装方法 Dec 17, 2023 am 09:39 AM

WebSocket と JavaScript を使用してオンライン予約システムを実装する方法 今日のデジタル時代では、ますます多くの企業やサービスがオンライン予約機能を提供する必要があります。効率的かつリアルタイムのオンライン予約システムを実装することが重要です。この記事では、WebSocket と JavaScript を使用してオンライン予約システムを実装する方法と、具体的なコード例を紹介します。 1. WebSocket とは何ですか? WebSocket は、単一の TCP 接続における全二重方式です。

JavaScript と WebSocket を使用してリアルタイムのオンライン注文システムを実装する方法 JavaScript と WebSocket を使用してリアルタイムのオンライン注文システムを実装する方法 Dec 17, 2023 pm 12:09 PM

JavaScript と WebSocket を使用してリアルタイム オンライン注文システムを実装する方法の紹介: インターネットの普及とテクノロジーの進歩に伴い、ますます多くのレストランがオンライン注文サービスを提供し始めています。リアルタイムのオンライン注文システムを実装するには、JavaScript と WebSocket テクノロジを使用できます。 WebSocket は、TCP プロトコルをベースとした全二重通信プロトコルで、クライアントとサーバー間のリアルタイム双方向通信を実現します。リアルタイムオンラインオーダーシステムにおいて、ユーザーが料理を選択して注文するとき

JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 Dec 17, 2023 pm 05:13 PM

JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 はじめに: 今日、天気予報の精度は日常生活と意思決定にとって非常に重要です。テクノロジーの発展に伴い、リアルタイムで気象データを取得することで、より正確で信頼性の高い天気予報を提供できるようになりました。この記事では、JavaScript と WebSocket テクノロジを使用して効率的なリアルタイム天気予報システムを構築する方法を学びます。この記事では、具体的なコード例を通じて実装プロセスを説明します。私たちは

簡単な JavaScript チュートリアル: HTTP ステータス コードを取得する方法 簡単な JavaScript チュートリアル: HTTP ステータス コードを取得する方法 Jan 05, 2024 pm 06:08 PM

JavaScript チュートリアル: HTTP ステータス コードを取得する方法、特定のコード例が必要です 序文: Web 開発では、サーバーとのデータ対話が頻繁に発生します。サーバーと通信するとき、多くの場合、返された HTTP ステータス コードを取得して操作が成功したかどうかを判断し、さまざまなステータス コードに基づいて対応する処理を実行する必要があります。この記事では、JavaScript を使用して HTTP ステータス コードを取得する方法を説明し、いくつかの実用的なコード例を示します。 XMLHttpRequestの使用

JavaScriptでinsertBeforeを使用する方法 JavaScriptでinsertBeforeを使用する方法 Nov 24, 2023 am 11:56 AM

使用法: JavaScript では、insertBefore() メソッドを使用して、DOM ツリーに新しいノードを挿入します。このメソッドには、挿入される新しいノードと参照ノード (つまり、新しいノードが挿入されるノード) の 2 つのパラメータが必要です。

JavaScript で HTTP ステータス コードを簡単に取得する方法 JavaScript で HTTP ステータス コードを簡単に取得する方法 Jan 05, 2024 pm 01:37 PM

JavaScript で HTTP ステータス コードを取得する方法の紹介: フロントエンド開発では、バックエンド インターフェイスとの対話を処理する必要があることが多く、HTTP ステータス コードはその非常に重要な部分です。 HTTP ステータス コードを理解して取得すると、インターフェイスから返されたデータをより適切に処理できるようになります。この記事では、JavaScript を使用して HTTP ステータス コードを取得する方法と、具体的なコード例を紹介します。 1. HTTP ステータス コードとは何ですか? HTTP ステータス コードとは、ブラウザがサーバーへのリクエストを開始したときに、サービスが

See all articles