検索
ホームページウェブフロントエンドjsチュートリアルJS try-catch ステートメントとエラー タイプの使用法

今回は、JS での try-catch ステートメントとエラーの型の使用方法について説明します。以下は、JS での try-catch ステートメントとエラーの型の使用上の注意点です。

アプリケーション ロジックは特定の関数を呼び出す理由を常に知っているため、エラーの処理に最適です。 try-catch の catch ブロックを空のままにしないでください。エラーを処理するために常に何かを記述する必要があります。たとえば、次のようなことは行わないでください:

try {
  somethingThatMightCauseAnError();
} catch (ex) {  // do nothing}

エラーが発生する可能性が高いことがわかっている場合は、そこから回復する方法を確実に知っています。エラーから正確に回復する方法は、開発モードと実際に運用環境に導入する場合では異なりますが、それは問題ありません。最も重要なことは、エラーを無視するのではなく実際に対処することです。

ECMA-262 仕様では 7 つのエラー タイプが指摘されています。これらの型は、さまざまなエラー条件が発生したときに JS エンジンで使用されます。もちろん、手動で作成することもできます。

エラー: すべてのエラーの基本的なタイプ。実際、エンジンはこの種のエラーをスローすることはありません。

EvalError: eval() 関数によるコードの実行中にエラーが発生した場合にスローされます。

RangeError: 数値がその境界を超えるとスローされます。たとえば、長さ -20 の配列 (new Array(-20);) を作成しようとした場合です。通常のコード実行では、このエラーが発生することは非常にまれです。

ReferenceError: 予期したオブジェクトが存在しない場合にスローされます。たとえば、null オブジェクト参照で関数を呼び出そうとした場合などです。

SyntaxError: コードに構文エラーがある場合にスローされます。

TypeError: 変数が予期された型ではない場合にスローされます。たとえば、新しい 10 または true の 'prop' です。

URIError: 不正にフォーマットされた URI 文字列が encodeURI()、encodeURIComponent()、decodeURI()、または decodeURIComponent() などの関数に渡されるとスローされます。

さまざまな種類のエラーを理解すると、より簡単に対処できるようになります。すべてのエラー タイプは Error から継承されるため、instanceof Error でタイプをチェックしても有用な情報は得られません。特定のエラー タイプをチェックすることで、エラーをより確実に処理できます。

try {  // 有些代码引发了错误} catch (ex) {  if (ex instanceof TypeError) {    // 处理TypeError错误
  } else if (ex instanceof ReferenceError) {    // 处理ReferenceError错误
  } else {    // 其他处理
  }
}

独自のエラーをスローし、それがエラーではなくデータ型である場合、独自のエラーとブラウザのエラー タイプを簡単に区別できます。ただし、実際の型のエラーをスローすることには、他の型のオブジェクトをスローすることに比べていくつかの利点があります。

まず第一に、上で説明したように、エラー メッセージはブラウザの通常のエラー処理メカニズム内で表示されます。次に、ブラウザは、スローされた Error オブジェクトに追加情報を付加します。この情報はブラウザーごとに異なりますが、行番号や列番号などのエラーのコンテキスト情報が提供され、一部のブラウザーではスタックとソース コードの情報も提供されます。もちろん、Error コンストラクターを使用すると、自分がスローしたエラーとブラウザーのエラーを区別できなくなります。

解決策は、独自のエラー タイプを作成し、それを Error から継承させることです。このアプローチにより、ブラウザーによってスローされたエラーとは異なる追加情報を提供できます。カスタム エラー タイプは、次のパターンを使用して作成できます。

function MyError (message) {  this.message = message;
}
MyError.prototype = new Error();

このコードには 2 つの重要な部分があります。メッセージ属性、ブラウザーが認識する必要があるエラー メッセージ文字列、およびプロトタイプを Error のインスタンスに設定することで、JS エンジンに対してエラー オブジェクトとして識別されます。次に、MyError のインスタンス オブジェクトをスローして、ブラウザーがネイティブ エラーのように応答できるようにします。

throw new MyError('Hello World!');

念のため言っておきますが、この方法は IE8 以前のブラウザではエラー メッセージを表示しません。代わりに、一般的な「例外がスローされましたがキャッチされません」というメッセージが表示されます。この方法の最大の利点は、カスタム エラー タイプが独自のエラーを検出できることです。

try {  // 有些代码引发了错误} catch (ex) {  if (ex instanceof MyError) {    // 处理自己的错误
  } else {    // 其他处理
  }
}

自分でスローしたエラーをすべて常にキャッチできるのであれば、IE の小さな愚かさは何の意味もありません。適切なエラー処理システムから得られるメリットは非常に大きいです。この方法により、開発者にエラーを正しく処理する方法を知らせる、より柔軟な情報が提供されます。

この記事の事例を読んだ後は、その方法を習得したと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。

推奨書籍:

Web 開発で null 比較を回避する方法

Web 開発でグローバル変数の使用を避ける必要がある理由

以上がJS try-catch ステートメントとエラー タイプの使用法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
es6数组怎么去掉重复并且重新排序es6数组怎么去掉重复并且重新排序May 05, 2022 pm 07:08 PM

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

JavaScript的Symbol类型、隐藏属性及全局注册表详解JavaScript的Symbol类型、隐藏属性及全局注册表详解Jun 02, 2022 am 11:50 AM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

原来利用纯CSS也能实现文字轮播与图片轮播!原来利用纯CSS也能实现文字轮播与图片轮播!Jun 10, 2022 pm 01:00 PM

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

JavaScript对象的构造函数和new操作符(实例详解)JavaScript对象的构造函数和new操作符(实例详解)May 10, 2022 pm 06:16 PM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

JavaScript面向对象详细解析之属性描述符JavaScript面向对象详细解析之属性描述符May 27, 2022 pm 05:29 PM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

javascript怎么移除元素点击事件javascript怎么移除元素点击事件Apr 11, 2022 pm 04:51 PM

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

整理总结JavaScript常见的BOM操作整理总结JavaScript常见的BOM操作Jun 01, 2022 am 11:43 AM

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。

foreach是es6里的吗foreach是es6里的吗May 05, 2022 pm 05:59 PM

foreach不是es6的方法。foreach是es3中一个遍历数组的方法,可以调用数组的每个元素,并将元素传给回调函数进行处理,语法“array.forEach(function(当前元素,索引,数组){...})”;该方法不处理空数组。

See all articles

ホット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ヘンタイを無料で生成します。

ホットツール

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境