序文Javascript エンジンはシングルスレッドなので、例外が発生すると、Javascript エンジンは通常、実行を停止し、後続のコードをブロックして例外メッセージをスローします。したがって、予測可能な例外については、それらをキャプチャして、ユーザーまたは開発者に正しく表示する必要があります。 エラーオブジェクト実行時エラーが発生すると、Error のインスタンスがスローされます。 エラー オブジェクトには 2 つのプロパティがあります。
エラーの作成
エラー タイプ js では、次の 7 つのエラー タイプが定義されています。
投げるJavaScript コードの中には、構文エラーがないのに論理エラーがあるものもあります。このようなエラーの場合、JavaScript は例外をスローしません。このとき、エラー オブジェクトのインスタンスを自分で定義し、throw ステートメントを使用して積極的に例外をスローすることができます。プログラムでは、throw ステートメントを使用して意図的に例外をスローすることができます。その構文は次のとおりです。
試して…捕まえて…最後に
try ステートメントには 3 つの形式があります。
最終ルールfinally ブロックで例外がスローされると、try ブロック内の例外が上書きされます。 試す { 試す { 新しいエラーをスローします('it1が見つかりません'); ついに 新しいエラーをスローします('見つかりません2'); } } キャッチ (エラー) { console.log(エラーメッセージ); } // 見つかりません2 finally ブロックから値を返すと、try と catch に return ステートメントがあるかどうかに関係なく、その値は try-catch-finally 全体の戻り値になります。これには、catch ブロックでスローされた例外が含まれます。 関数テスト() { 試す { 新しいエラーをスローします('it1が見つかりません'); 1 を返します。 } キャッチ (エラー) { 新しいエラーをスローします('見つかりません2'); 2を返します。 ついに 3 を返します。 } } コンソール.log(テスト()); // 3 トライ/キャッチパフォーマンスよく知られている反最適化パターンはtry/catchを使うことである。 V8 (およびおそらく他の JS エンジン) では、try/catch ステートメントを使用する関数は V8 コンパイラによって最適化できません。 ウィンドウ.onerrorwindow.onerrorにイベントリスナー関数を定義すると、プログラム内の他のコードによって生成されたキャッチされていない例外が、window.onerrorに登録されたリスナー関数によってキャッチされることが多くなります。
約束の例外Promise で例外がスローされました
Promise で例外をキャッチする
知らせ JavaScript 関数では、関数の実行を中断できるのは return / yield / throw のみであり、reject はそれ以上の実行を阻止しません。 例: 返品せずに拒否する Promise.resolve() .then(() => { console.log('実行前に拒否'); 拒否(新しいエラー('エラーをスロー')); console.log('実行後拒否'); }) .catch((エラー) => { console.log(エラーメッセージ); }); // 実行拒否の前に // エラーをスローする // 実行後拒否 リターンを使用して拒否する Promise.resolve() .then(() => { console.log('実行前に拒否'); 拒否を返します(新しい Error('throw error')); console.log('after execute deny'); //*** 違いはここにあります。return が返された場合、ここでは実行されません}) .catch((エラー) => { console.log(エラーメッセージ); }); // 実行拒否の前に // エラーをスローする Vue 例外キャプチャVue.config.errorHandler = (err, vm, info) => { console.error("vue errorHandler によってエラーがキャプチャされました"); コンソールエラー(err); コンソールエラー(vm); コンソールエラー(情報); }; 要約するこれで、JavaScript の基本に関するエラーキャッチメカニズムに関するこの記事は終了です。より関連性の高い js エラーキャッチメカニズムのコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: Mybatis での動的 SQL ステートメント分析
>>: Linux ソフトウェアのインストール場所を確認する簡単な方法
目次序文1. 基本環境1. サービス配信2. ネットワーク構成(全ノード) 3. SSHパスワードフ...
目次1. Jenkinsの紹介2. Jenkinsをインストールしてデプロイする1. 環境情報2. ...
序文1. この記事で使用したツールは、https://github.com/gianlucabore...
序文Web アプリケーションでは、トラフィックを節約し、転送データのサイズを縮小し、転送効率を向上さ...
NProgress は、ページがジャンプしたときにブラウザの上部に表示される進行状況バーです。公式ウ...
<br />ナビゲーション設計は構造設計における主要なタスクの 1 つです。ソフトウェア...
目次簡単な紹介間隔の設定説明するパラメータ戻り値使用法タイムアウトの設定説明するパラメータ使用法:タ...
1. 永続的な統計情報の重要性:統計は、MySQL が実行プランを生成するためのガイドとして使用され...
目標: 辺の長さが等しい正方形を作成する方法 1: 単位 vw を使用する (ps これが最も簡単な...
目次1. React フックと純粋関数2. シンプルなmyUseState 3. myUseStat...
2 日前、Raspberry Pi サーバーを Ubuntu 20 にアップグレードしました。今日...
この記事では、ブロック崩しピンボールゲームを実装するためのJSの具体的なコードを参考までに紹介します...
質問1:エラーを報告する書き込み方法: GRANT OPTION を使用して、'123123...
目次クロスドメインの理由JSONP Nginxソリューションバックエンドソリューションクロスドメイン...
目次$nextTick() $forceUpdate() $セット() .sync——2.3.0 以...