Asial Blog

Recruit! Asialで一緒に働きませんか?

【Javascript】consoleオブジェクトが持つlog以外の便利メソッド18(後編)

カテゴリ :
フロントエンド(HTML5)
タグ :
Tech
JavaScript
HTML5
Firebug
Webインスペクター
こんにちは、橋本です。

前回にひきつづき、Safari、ChromeのWebインスペクターやFirefoxのFireBugで使えるconsoleオブジェクトの使い方について書いてみたいと思います。

consoleオブジェクトには以下の19個(logを除くと18個)のメソッドがあります。

  • assert

  • count

  • debug

  • dir

  • dirxml

  • error

  • group

  • groupCollapsed

  • groupEnd

  • info

  • log

  • markTimeline

  • profile

  • profileEnd

  • time

  • timeEnd

  • timeStamp

  • trace

  • warn


そのうち前回は、assertメソッドからgroupEndメソッドまで見て行きました。
今回はinfoメソッドからwarnメソッドまでの使い方について書いていきたいと思います。

infoメソッド



console.info(message-object)

引数で渡されたメッセージをインフォメーションアイコンつきで表示するメソッドです。
Safariではアイコンが表示されませんでしたが、FireBugでは表示されています。

  1. var hoge = 'インフォだよ?';
  2. console.info(hoge);





前回紹介したerrorメソッドや、のちほど紹介するwarnメソッドと一緒につかって、メッセージに意味付けを行うと便利に使えると思います。

logメソッド



console.log(message-object)

ご存知logメソッドです。引数で渡された値を出力します。
引数の値なのですが、カンマ区切りで複数渡すことも可能です。

また、あまり知られていないと思いますが、logメソッド(debugなどのメッセージを出力する系のメソッドも含む)では、printf-styleのプレスホルダの一部を使用することも可能です。


  • %s 文字列

  • %d, %i 数値

  • %f 浮動小数点数

  • %o オブジェクトへのリンク


など。

FireBugでは、%cプレースホルダをつかって、メッセージのスタイルを設定することもできます。

以下、サンプルです。

  1. var str = 'ほげほげ',
  2.     intNum = 10,
  3.     floatNum = 10.12345678,
  4.     obj = {hoge: 'hoge'},
  5.     styl = 'color: hsl(0, 50%, 50%);font-weight: bold;';
  6.  
  7. console.log(str, intNum, floatNum, obj);
  8. console.log('文字列: %s', str);
  9. console.log('数値(整数): %i', intNum);
  10. console.log('数値(整数): %d', intNum);
  11. console.log('数値(浮動小数点数): %f', floatNum);
  12. console.log('オブジェクト: %o', obj);
  13. console.log('%cFireBugでスタイル指定', styl);





プレースホルダはなにげに便利なので、今まで使ったことのない人は是非使ってみてください。

markTimelineメソッド



console.markTimeline("string");

markTimelineメソッドは、その他のコンソールに出力するタイプのメソッドとは異なり、WebインスペクターやFirebugのタイムラインビュー上でメソッドが呼ばれたポイントに、引数で渡されたラベルを表示するというものになります。

サンプルと実行結果をお見せしたいのですが、自分の実行環境では実行結果を確認できなかったため、今回はスキップさせてください。すみません。


profileメソッド, profileEndメソッド



console.profile([title]);
console.profileEnd([title]);

profileメソッドとprofileEndメソッドは、関数の解析(実行にかかった時間など)を行うためのメソッドです。
profileメソッドが呼ばれてから、profileEndメソッドが呼ばれるまでの間に実行された関数について解析を行います。
profileメソッドとprofileEndメソッドにはそれぞれタイトルを設定することが出来、profileEndメソッドにタイトルを渡した場合、そのタイトルに対応するprofileメソッドのみ解析を終了します。(指定しない場合には、すべてのprofileメソッドの解析を終了します。)

以下、サンプルです。

  1. function hoge() {
  2.     var ret = 0;
  3.     for (var i = 0; i < 100000; i++) {
  4.         ret += i;
  5.     }
  6.  
  7.     console.log(ret);
  8. }
  9.  
  10. function fuga() {
  11.     var ret = 1;
  12.     for (var i = 1; i <= 10; i++) {
  13.         ret *= i;
  14.     }
  15.  
  16.     console.log(ret);
  17. }
  18.  
  19. console.profile('a');
  20.  
  21. console.profile('b');
  22. hoge();
  23. console.profileEnd('b');
  24.  
  25. console.profile('c');
  26. fuga();
  27. console.profileEnd('c');
  28.  
  29. console.profileEnd('a');





特定箇所の関数の実行速度や実行内容を確認したい場合に有用ですね。

timeメソッド, timeEndメソッド



console.time(name);
console.timeEnd(name);

timeメソッドとtimeEndメソッドは、タイマーの開始と終了を行うメソッドです。timeメソッドでタイマーを開始し、timeEndメソッドでタイマーを終了し、時間をlogに表示します。

以下、サンプルです。

  1. function hoge() {
  2.     var ret = 0;
  3.     for (var i = 0; i < 10000000; i++) {
  4.         ret += i;
  5.     }
  6.  
  7.     console.log(ret);
  8. }
  9.  
  10. function fuga() {
  11.     hoge();
  12.     hoge();
  13. }
  14.  
  15. console.time('all');
  16.  
  17. console.time('hoge');
  18. hoge();
  19. console.timeEnd('hoge');
  20.  
  21. console.time('fuga');
  22. fuga();
  23. console.timeEnd('fuga');
  24.  
  25. console.timeEnd('all');



実行速度を計りたいときは、これで決まりですね。

timeStampメソッド



console.timeStamp("string");

timeStampメソッドは、メソッド実行時の時間をlogに出力するメソッドです。
FireBugでは実行結果を確認できたのですが、Safari, Chromeでは実行結果を確認できませんでした。

以下、サンプルです。

  1. function hoge() {
  2.     var ret = 0;
  3.     for (var i = 0; i < 10000000; i++) {
  4.         ret += i;
  5.     }
  6.  
  7.     console.log(ret);
  8. }
  9.  
  10. function fuga() {
  11.     hoge();
  12.     hoge();
  13. }
  14.  
  15. console.timeStamp('start');
  16.  
  17. hoge();
  18. fuga();
  19.  
  20. console.timeStamp('stop');



このメソッドの使いドコロは、いまいち思い浮かびませんでした。
常にスクリプトの最初に実行しておくようにすれば、logを見て、

「いっけねー、もうこんな時間!」

なんて感じで、時間管理に便利かもしれませんね。

traceメソッド



console.trace();

traceメソッドは、メソッド実行時のスタックトレースを表示するメソッドです。

以下、サンプルです。

  1. function hoge() {
  2.     function fuga() {
  3.         function piyo() {
  4.             console.trace();
  5.         }
  6.  
  7.         piyo();
  8.     }
  9.  
  10.     fuga();
  11. }
  12.  
  13. hoge();



どのメソッドを経由して来たのか、ということを確認したい場合には有用かもしれませんね。

warnメソッド



console.warn(message-object)

引数で渡されたメッセージを警告アイコンつきで表示するメソッドです。

  1. var hoge = '警告です!!';
  2. console.warn(hoge);




前回紹介したerrorメソッドや、infoメソッドと一緒につかって、メッセージに意味付けを行うと便利に使えると思います。


以上、前回と今回の2回に渡り、consoleオブジェクトのメソッドについて見てきました。
使えそうなものや、いまいち使えなさそうなものなど様々ありますが、
いろいろと試してみて、便利なメソッドは是非使っていっていただければ思います。