ホームページ  >  記事  >  ウェブフロントエンド  >  JavaScript で 6 つのエラー タイプを共有する

JavaScript で 6 つのエラー タイプを共有する

小云云
小云云オリジナル
2018-02-05 10:21:361460ブラウズ

js のコンソール エラー メッセージは主に 2 つのカテゴリに分類されます。最初のカテゴリは構文エラーです。このタイプのエラーが事前解析プロセス中に発生した場合、js ファイル全体が実行されません。別の種類のエラーは総称して例外と呼ばれます。この種類のエラーでは、エラーが発生した行以降のコードは実行できなくなりますが、その行より前のコードは影響を受けません。

1. SyntaxError: 構文エラー

// 1. Syntax Error: 语法错误
// 1.1 变量名不符合规范
var 1       // Uncaught SyntaxError: Unexpected number
var 1a       // Uncaught SyntaxError: Invalid or unexpected token
// 1.2 给关键字赋值
function = 5     // Uncaught SyntaxError: Unexpected token =

2. Uncaught ReferenceError: 参照エラー

存在しない変数を参照したときに発生するエラー。関数や関数の代入の結果など、代入できないオブジェクトに値を代入します。

// 2.1 引用了不存在的变量
a()       // Uncaught ReferenceError: a is not defined
console.log(b)     // Uncaught ReferenceError: b is not defined
// 2.2 给一个无法被赋值的对象赋值
console.log("abc") = 1   // Uncaught ReferenceError: Invalid left-hand side in assignment

3. RangeError: 範囲エラー

RangeError は、オブジェクトが有効範囲のすぐ外にある場合に発生するエラーです。主な状況はいくつかあります。1 つ目は、配列の長さが負の数であること、2 つ目は、Number オブジェクトのメソッド パラメーターが範囲外であり、関数スタックが最大値を超えていることです。

// 3.1 数组长度为负数
[].length = -5      // Uncaught RangeError: Invalid array length
// 3.2 Number对象的方法参数超出范围
var num = new Number(12.34)
console.log(num.toFixed(-1))   // Uncaught RangeError: toFixed() digits argument must be between 0 and 20 at Number.toFixed
// 说明: toFixed方法的作用是将数字四舍五入为指定小数位数的数字,参数是小数点后的位数,范围为0-20.

4. TypeError TypeError

変数またはパラメーターが予期された型ではない場合に発生するエラー。たとえば、文字列やブール値などの新しいプリミティブ型を使用し、オブジェクトに存在しないメソッドを呼び出すと、このエラーがスローされます。これは、新しいコマンドのパラメータがコンストラクターである必要があるためです。

// 4.1 调用不存在的方法
123()        // Uncaught TypeError: 123 is not a function
var o = {}
o.run()        // Uncaught TypeError: o.run is not a function
// 4.2 new关键字后接基本类型
var p = new 456      // Uncaught TypeError: 456 is not a constructor

5. URIError、URLエラー

主に関連関数のパラメータが間違っています。

decodeURI("%")     // Uncaught URIError: URI malformed at decodeURI

URI 関連のパラメーターが正しくない場合にスローされるエラー。主に、encodeURI、decodeURI()、encodeURIComponent()、decodeURIComponent()、escape()、unescape() の 6 つの関数が関係します。

6. EvalError eval()関数実行エラー

ES5以下のJavaScriptでは、eval()関数が正しく実行されなかった場合、evalErrorエラーがスローされます。

たとえば、次の状況:

var myEval = eval;
myEval("alert('call eval')");

このエラーは ES5 以降の JavaScript ではスローされなくなりましたが、新しいキーワードを使用してこのタイプのエラー プロンプトをカスタマイズできることに注意してください。

上記の 6 つの派生エラーは、元の Error オブジェクトとともに、すべてコンストラクターです。開発者はこれらを使用してエラー オブジェクトのインスタンスを生成できます。

new Error([message[,fileName[,lineNumber]]]),

最初のパラメータはエラー メッセージを表し、2 番目はファイル名、3 番目は行番号です。

関連する推奨事項:

JS 一般的なエラー タイプの概要

php 詳細なエラー タイプとシールド方法

php 一般的なエラー タイプとシールド方法

以上がJavaScript で 6 つのエラー タイプを共有するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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