Console についてまとめる

(※この記事は 別媒体に投稿した記事 のバックアップです。 canonical も設定しています)

2020-10-19

※この記事ははてなブログ別アカウント(hyiromori)から引っ越しました

はじめに

JavaScript を使って開発していると、console を使ってログ出力やデバッグしたりすることもありますが、意外とたくさん種類があることが分かったので一通りまとめてみました。

console - Web API | MDN

上記のMDNのドキュメントをもとに調べました。
より詳しい使い方なども書いてあるので、一度読むことをオススメします。

動作は Google Chrome で確認しています。

image.png

console.log()

一番良く使うやつ。

image.png

これは知らなかった・・・。ドキュメントはちゃんと読んでみるものですね。

オブジェクトのログ出力

console.log(obj) を使わず、 console.log(JSON.parse(JSON.stringify(obj))) を使用してください。

これにより、ログを記録した瞬間の obj の値を確実に見ることができます。こうしないと、多くのブラウザーでは値が変化したときに常に更新されるライブビューになります。これは望むことではないかもしれません。

console.log() - Web API | MDN

console.error()

ERRORレベルのログを出力する

image.png

console.warn()

WARNレベルのログを出力する

image.png

console.info()

INFOレベルのログを出力する。

image.png

console.debug()

DEBUGレベルのログを出力する

capture.png

console.dir()

JavaScript オブジェクトのプロパティの対話的なリストを表示する。

capture.gif

Google Chrome の場合、HTMLElement を入れると属性値が確認できるので、場合によっては便利。

console.time(), console.timeLog console.timeEnd()

時間を計測する。
timeLog は途中で呼び出して、timeEnd は計測終了時に呼び出すような使い方。

image.png

console.trace()

スタックトレースを出力する。

image.png

非標準

標準化されていないメソッドなので、使用する環境によっては使えない可能性があるらしい。

console.assert()

第1引数の結果が false ならメッセージを表示する。

capture.png

console.clear()

コンソールの内容を消去する。

capture.gif

console.count([label])

ラベルに応じて、呼び出された回数を出力する

capture.png

console.countReset() でリセットもできる。

console.dirxml()

XML/HTML 要素の子孫要素の対話式ツリーを表示する。

image.png

console.group(), console.groupCollapsed(), console.groupEnd()

ログ出力をインデントする。

image.png

groupCollapsed() はデフォルトで展開されない状態になる(自分で開く必要がある)

console.profile(), console.profileEnd()

ブラウザー内蔵のプロファイラー を実行する。
Google Chrome で試してみたところエラーにはならないけど結果を見れるところが見つけられなかった・・・。

console.table()

データを表形式で出力する。

image.png

console.timeStamp()

ブラウザの Timeline やタイムラインツールにマーカーを 1 個追加します。
Google Chrome にタイムラインツールはなくなったのかな・・・?