【JavaScript】ブレイクポイントを使いやすくするためのtry, catch

 例えば、次のコードがあるとします。

const items = [1,2,3,4,5];
let i = 0;
function clickEvent(){
    document.getElementById('txt-box').innerText = items[i++].toString();
}
document.getElementById('increment').addEventListener('click', clickEvent);

 クリックの度に変数 i を 1 増加してそのインデックスの配列 items の中身を表示するプログラムです。これを実行するとクリックを何度かしたところで null の toString() を参照することになってエラーで落ちます。
 なぜエラーになるかを調べる時にブラウザ上のブレイクポイントが使えます。しかし、上プログラムの様にエラー原因となった行と同じ場所を何度も通るプログラムでブレイクポイントを進めるのは億劫です。どのくらい億劫かは次動画で示されます。

 クリック数が多い上、動画の終わりがエラー直前のストップなのですがさっぱりわかりません。エラーが起きるタイミングでのみブレイクしたくなります。これをtry, catchで実現します。実現すると次のコードの様になります。

const items = [1,2,3,4,5];
let i = 0;
function clickEvent(){
    try{
        document.getElementById('txt-box').innerText = items[i++].toString();
    }catch(e){
        console.error(e);
    }
}
document.getElementById('increment').addEventListener('click', clickEvent);

 このコードを動かすと次のようになります。

 エラーが起きるタイミングでのみブレイクポイントが働きます。また、JavaScript組み込み例外クラスのプロパティstackを参照することによってこの例外がどこから投げられたものかもわかります。このやり方をすることでデバッグが幾分か快適になります。
Error.prototype.stack – JavaScript | MDN

>株式会社シーポイントラボ

株式会社シーポイントラボ

TEL:053-543-9889
営業時間:9:00~18:00(月〜金)
住所:〒432-8003
   静岡県浜松市中央区和地山3-1-7
   浜松イノベーションキューブ 315
※ご来社の際はインターホンで「316」をお呼びください

CTR IMG