web-dev-qa-db-ja.com

IE 8でJavascriptをデバッグする方法

IE 8でJavaScriptをデバッグするにはどうすればよいですか?

IE 8への更新後、Visual StudioでのJavaScriptデバッグは機能しません。

63
Cédric Boivin

今日、IE 8に統合された開発者ツールバープラグインでJavascriptをデバッグできることを発見しました。

  • タブの右側にあるツールバーの▼ツールをクリックします。
  • 開発ツールを選択します。開発者ツールのダイアログが開きます。
  • ダイアログのScriptタブをクリックします。
  • デバッグの開始ボタンをクリックします。

プロのブラウザーのデバッガーと同様に、ウォッチ、ブレークポイント、コールスタックなどを使用できます。

JavaScriptコードでdebugger;ステートメントを使用して、ブレークポイントを設定することもできます。

81
Cédric Boivin

IE8開発者ツールバーのデバッグに関する詳細情報は、 JScriptのデバッグ または 開発者ツールを使用したスクリプトのデバッグ で取得できます。

8
Lil'Monkey

これは、コードをステップ実行したりエラーで中断したりするのには役立ちませんが、すべてのブラウザーでプロジェクトの同じデバッグコンソールを取得するのに便利な方法です。

myLog = function() {
    if (!myLog._div) { myLog.createDiv(); }

    var logEntry = document.createElement('span');
    for (var i=0; i < arguments.length; i++) {
        logEntry.innerHTML += myLog.toJson(arguments[i]) + '<br />';
    }
    logEntry.innerHTML += '<br />';

    myLog._div.appendChild(logEntry);
}
myLog.createDiv = function() {
    myLog._div = document.body.appendChild(document.createElement('div'));
    var props = {
        position:'absolute', top:'10px', right:'10px', background:'#333', border:'5px solid #333', 
        color: 'white', width: '400px', height: '300px', overflow: 'auto', fontFamily: 'courier new',
        fontSize: '11px', whiteSpace: 'nowrap'
    }
    for (var key in props) { myLog._div.style[key] = props[key]; }
}
myLog.toJSON = function(obj) {
    if (typeof window.uneval == 'function') { return uneval(obj); }
    if (typeof obj == 'object') {
        if (!obj) { return 'null'; }
        var list = [];
        if (obj instanceof Array) {
            for (var i=0;i < obj.length;i++) { list.Push(this.toJson(obj[i])); }
            return '[' + list.join(',') + ']';
        } else {
            for (var prop in obj) { list.Push('"' + prop + '":' + this.toJson(obj[prop])); }
            return '{' + list.join(',') + '}';
        }
    } else if (typeof obj == 'string') {
        return '"' + obj.replace(/(["'])/g, '\\$1') + '"';
    } else {
        return new String(obj);
    }
}

myLog('log statement');
myLog('logging an object', { name: 'Marcus', likes: 'js' });

これはかなり急いで組み立てられ、少しずさんですが、それでも便利であり、簡単に改善できます!

6
Marcus Westin

これをマーカスウェスティンの返信へのコメントとして追加したかったのですが、リンクが見つかりません。もっと評判が必要なのでしょうか?


とにかく、おかげで、このコードスニペットはIEでの迅速なデバッグに役立つことがわかりました。動作を停止した問題を修正するためにいくつかの簡単な調整を行いました。また、自動的にスクロールダウンし、固定位置を使用してビューポートに表示されるようにしました。誰かが便利だと思った場合の私のバージョンは次のとおりです。

myLog = function() {

    var _div = null;

    this.toJson = function(obj) {

        if (typeof window.uneval == 'function') { return uneval(obj); }
        if (typeof obj == 'object') {
            if (!obj) { return 'null'; }
            var list = [];
            if (obj instanceof Array) {
                    for (var i=0;i < obj.length;i++) { list.Push(this.toJson(obj[i])); }
                    return '[' + list.join(',') + ']';
            } else {
                    for (var prop in obj) { list.Push('"' + prop + '":' + this.toJson(obj[prop])); }
                    return '{' + list.join(',') + '}';
            }
        } else if (typeof obj == 'string') {
            return '"' + obj.replace(/(["'])/g, '\\$1') + '"';
        } else {
            return new String(obj);
        }

    };

    this.createDiv = function() {

        myLog._div = document.body.appendChild(document.createElement('div'));

        var props = {
            position:'fixed', top:'10px', right:'10px', background:'#333', border:'5px solid #333', 
            color: 'white', width: '400px', height: '300px', overflow: 'auto', fontFamily: 'courier new',
            fontSize: '11px', whiteSpace: 'nowrap'
        }

        for (var key in props) { myLog._div.style[key] = props[key]; }

    };


    if (!myLog._div) { this.createDiv(); }

    var logEntry = document.createElement('span');

    for (var i=0; i < arguments.length; i++) {
        logEntry.innerHTML += this.toJson(arguments[i]) + '<br />';
    }

    logEntry.innerHTML += '<br />';

    myLog._div.appendChild(logEntry);

    // Scroll automatically to the bottom
    myLog._div.scrollTop = myLog._div.scrollHeight;

}
3
poshaughnessy