ホームページ ウェブフロントエンド jsチュートリアル JavaScript デバッグ手順_JavaScript スキル

JavaScript デバッグ手順_JavaScript スキル

May 16, 2016 pm 06:25 PM
javascript デバッグ

以前は、JavaScript の IO サポートは非​​常に弱く、対応するテキスト ファイルに書き込むことができませんでした。さらに、例外オブジェクト Error は均一ではなく、詳細なスタックを出力できませんでした。例外オブジェクトのカスタマイズは、通常はそのメッセージ属性しか表示されないため、非常に不快な方法です。さらに、他のカスタム属性は最も遅い for...in ループを使用して調べる必要があります。現時点では、ブラウザのさまざまなプライベート実装に頼るしか方法はありません。たとえば、Firefox には console.log があります。以下は、コンソール オブジェクトのメソッドのリストです。firebug の詳細な使用方法については、この記事を参照してください。

機能 説明 log(obj[, obj, ...]) コンソールにメッセージを出力します。複数のパラメータを入力でき、出力はスペースで区切られます。
函数 说明
log(obj[, obj, ...]) 向控制台输出一个信息。可以输入多个参数,输出将已空格分隔各参数输出。
第一参数可以包含格式化文本,例如:
log(‘这里有%d个%s',count,apple);
字符串格式:
%s:字符串。
%d, %i:数字。
%f: 浮点数。
%o -超链接对象。
debug(obj[, obj, ...]) 向控制台输出一个信息,信息包含一个超链接链接到输出位置。
info(obj[, obj, ...]) 向控制台输出一个带信息图标和背景颜色的信息,信息包含一个超链接链接到输出位置。
warn(obj[, obj, ...]) 向控制台输出一个带警告图标和背景颜色的信息,信息包含一个超链接链接到输出位置。
error(obj[, obj, ...]) 向控制台输出一个带错误图标和背景颜色的信息,信息包含一个超链接链接到输出位置。
assert(expression[, obj, ...]) 测试一个表示是否为true,如果为false,提交一个例外信息到控制台。
dir(obj) 列出对象的所有属性。
dirxml(node) 列出HTML或XML Element的XML源树。
trace() 输出堆栈的调用入口。
group(obj[, obj, ...]) 将信息分组再输出到控制台。通过groupEnd()结束分组。
groupEnd() 结束分组输出。
time(name) 创建一个名称为name的计时器,计算代码的执行时间,调用timeEnd(name)停止计时器并输出执行时间。
timeEnd(name) 停止名称为name的计时器并输出执行时间。
profile([title]) 开始对脚本进行性能测试,title为测试标题。
profileEnd() 结束性能测试。
count([title]) 计算代码的执行次数。titile作为输出标题。
最初のパラメータには、フォーマットされたテキストを含めることができます。例:
log(‘There are %d %s’, count, apple);
文字列形式: デバッグ(obj[, obj, ...]) 出力場所へのハイパーリンクを含むメッセージをコンソールに出力します。 情報(obj[, obj, ...]) メッセージ アイコンと背景色を使用してメッセージをコンソールに出力します。メッセージには、出力場所へのハイパーリンクが含まれます。 警告(obj[, obj, ...]) 警告アイコンと背景色を含むメッセージをコンソールに出力します。メッセージには、出力場所へのハイパーリンクが含まれます。 エラー(obj[, obj, ...]) エラー アイコンと背景色を含むメッセージをコンソールに出力します。メッセージには、出力場所へのハイパーリンクが含まれます。 assert(expression[, obj, ...]) 表現が true かどうかをテストし、false の場合は例外メッセージをコンソールに送信します。 ディレクトリ(obj) オブジェクトのすべてのプロパティをリストします。 dirxml(ノード) HTML または XML 要素の XML ソース ツリーをリストします。 トレース() 出力スタックの呼び出しエントリ。 グループ(obj[, obj, ...]) 情報をグループ化してコンソールに出力します。 groupEnd() を使用してグループを終了します。 グループエンド() グループ出力を終了します。 時間(名前) name という名前のタイマーを作成し、コードの実行時間を計算し、timeEnd(name) を呼び出してタイマーを停止し、実行時間を出力します。 終了時刻(名前) name という名前のタイマーを停止し、実行時間を出力します。 プロフィール([タイトル]) スクリプトのパフォーマンス テストを開始します。タイトルはテストのタイトルです。 profileEnd() パフォーマンステストを終了します。 カウント([タイトル]) コードの実行回数をカウントします。 title を出力タイトルとして指定します。 firebug については詳しく説明しません。IE8 にも console.log がありますが、これは F12 を押してデバッグ モードに入った場合にのみ有効になります。それ以外の場合は、エラーが報告されます。エラーを報告しないようにするには、通常は空のオブジェクトを実装して上書きする必要があります。


コードをコピー


コードは次のとおりです。


if (!window.console ){
window .console = {};
varmessages = ["log"、"debug"、"info"、"warn"、"error"、"assert"、"dir"、"dirxml"、
"group ", "groupEnd", "time", "timeEnd", "count", "trace", "profile", "profileEnd"],
noop = function(){}
for (var i = 0 , method; method=methods[i ];) window.console[method] = noop; } おそらく、opera9.5x 以降に追加のものがあります。ドラゴンフライイーストと呼ばれています。明らかに、firebug のさまざまなログ出力と比較することはできません。提供されるのは、opera.postError メソッドだけです。


コードをコピー

コードは次のとおりです。
if (window.opera && opera.postError ) { opera.postError(message); } Safari にも console.log があります。これは Web Inspector コンポーネントに基づいており、Firefox に似ていますが、フルーツ人間ではないので、Firebug ほど多くのメソッドはありません。新興ブラウザ Chrome の場合、拡張機能に Firebug がインストールされている Chrome バージョンを検索できるようになりました。
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

C++ 関数のデバッグの詳細な説明: マルチスレッド関数の問題をデバッグするには? C++ 関数のデバッグの詳細な説明: マルチスレッド関数の問題をデバッグするには? May 02, 2024 pm 04:15 PM

C++ マルチスレッド デバッグでは、次のように GDB を使用できます。 1. デバッグ情報のコンパイルを有効にします。 2. ブレークポイントを設定します。 3. infothread を使用してスレッドを切り替えます。 5. next、stepi、および locals を使用してデバッグします。実際のケースのデバッグ デッドロック: 1. threadapplyallbt を使用してスタックを出力します。 2. スレッドのステータスを確認します。 3. メイン スレッドにシングル ステップでアクセスし、デッドロックを解決します。

LeakSanitizer を使用して C++ メモリ リークをデバッグするにはどうすればよいですか? LeakSanitizer を使用して C++ メモリ リークをデバッグするにはどうすればよいですか? Jun 02, 2024 pm 09:46 PM

LeakSanitizer を使用して C++ メモリ リークをデバッグするにはどうすればよいですか? LeakSanitizer をインストールします。コンパイル フラグを介して LeakSanitizer を有効にします。アプリケーションを実行し、LeakSanitizer レポートを分析します。メモリ割り当てタイプと割り当て場所を特定します。メモリ リークを修正し、動的に割り当てられたメモリがすべて解放されるようにします。

golang 関数のデバッグと分析へのショートカット golang 関数のデバッグと分析へのショートカット May 06, 2024 pm 10:42 PM

この記事では、実行の一時停止、変数の確認、ブレークポイントの設定に使用される組み込みデバッガー dlv など、Go 関数のデバッグと分析のためのショートカットを紹介します。ログ記録。ログ パッケージを使用してメッセージを記録し、デバッグ中に表示します。パフォーマンス分析ツール pprof は、コール グラフを生成してパフォーマンスを分析し、gotoolpprof を使用してデータを分析します。実際のケース: pprof を通じてメモリ リークを分析し、リークの原因となる関数を表示するコール グラフを生成します。

Java ラムダ式で効率的なデバッグを行うにはどうすればよいですか? Java ラムダ式で効率的なデバッグを行うにはどうすればよいですか? Apr 24, 2024 pm 12:03 PM

ラムダ式を効率的にデバッグします: IntelliJ IDEA デバッガー: 変数宣言またはメソッドにブレークポイントを設定し、内部変数と状態を検査し、実際の実装クラスを確認します。 Java9+JVMTI: ランタイム JVM に接続して、識別子の取得、バイトコードの検査、ブレークポイントの設定、および実行中の変数とステータスの監視を行います。

Java 同時プログラミングで同時実行テストとデバッグを実行するにはどうすればよいですか? Java 同時プログラミングで同時実行テストとデバッグを実行するにはどうすればよいですか? May 09, 2024 am 09:33 AM

同時実行テストとデバッグ Java 同時プログラミングにおける同時実行テストとデバッグは非常に重要であり、次の手法が利用可能です。 同時実行テスト: 単体テスト: 単一の同時タスクを分離してテストします。統合テスト: 複数の同時タスク間の相互作用をテストします。負荷テスト: 高負荷時のアプリケーションのパフォーマンスとスケーラビリティを評価します。同時実行デバッグ: ブレークポイント: スレッドの実行を一時停止し、変数を検査するかコードを実行します。ロギング: スレッドのイベントとステータスを記録します。スタック トレース: 例外のソースを特定します。視覚化ツール: スレッドのアクティビティとリソースの使用状況を監視します。

PHP 非同期コードをデバッグする方法 PHP 非同期コードをデバッグする方法 May 31, 2024 am 09:08 AM

PHP 非同期コードをデバッグするためのツールには、次のものがあります。 Psalm: 潜在的なエラーを検出する静的分析ツール。 ParallelLint: 非同期コードを検査し、推奨事項を提供するツール。 Xdebug: セッションを有効にしてコードをステップ実行することで、PHP アプリケーションをデバッグするための拡張機能。その他のヒントには、ロギング、アサーションの使用、ローカルでのコードの実行、単体テストの作成などがあります。

PHP デバッグ エラー: よくある間違いへのガイド PHP デバッグ エラー: よくある間違いへのガイド Jun 05, 2024 pm 03:18 PM

一般的な PHP デバッグ エラーには次のものがあります。 構文エラー: コード構文をチェックして、エラーがないことを確認します。未定義の変数: 変数を使用する前に、変数が初期化され、値が割り当てられていることを確認してください。セミコロンの欠落: すべてのコード ブロックにセミコロンを追加します。関数が未定義です: 関数名のスペルが正しいことを確認し、正しいファイルまたは PHP 拡張子がロードされていることを確認してください。

C++ 関数のデバッグの詳細な説明: 例外処理を含む関数の問題をデバッグするにはどうすればよいですか? C++ 関数のデバッグの詳細な説明: 例外処理を含む関数の問題をデバッグするにはどうすればよいですか? Apr 30, 2024 pm 01:36 PM

例外処理を含む C++ デバッグ関数は、例外ポイント ブレークポイントを使用して例外の場所を特定します。 gdb で catch コマンドを使用して、例外情報とスタック トレースを出力します。例外ロガーを使用して、メッセージ、スタック トレース、変数値などの例外をキャプチャおよび分析します。

See all articles