[转]Web程序员必须知道的 Console 对象里的九个方法

 一、显示信息的命令

  

01 1: <!DOCTYPE html>
02  2: <html>
03  3: <head>
04  4:     <title>常用console命令</title>
05  5:     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
06  6: </head>
07  7: <body>
08  8:     <script type="text/javascript">
09  9:         console.log('hello');
10 10:         console.info('信息');
11 11:         console.error('错误');
12 12:         console.warn('警告');
13 13:     </script>
14 14: </body>
15 15: </html>

  最常用的就是console.log了。

 

  二:占位符

 

  console上述的集中度支持printf的占位符格式,支持的占位符有:字符(%s)、整数(%d或%i)、浮点数(%f)和对象(%o)

1 <font face="Tahoma, Arial, Helvetica, snas-serif"><span style="font-size: 16.3799991607666px; white-space: normal;"><b></b></span></font>   1: <script type="text/javascript">
2    2:         console.log("%d年%d月%d日",2011,3,26);
3    3: </script>

 

  效果:

 

  三、信息分组

 

01 1: <!DOCTYPE html>
02  2: <html>
03  3: <head>
04  4:     <title>常用console命令</title>
05  5:     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
06  6: </head>
07  7: <body>
08  8:     <script type="text/javascript">
09  9:         console.group("第一组信息");
10 10:
11 11:         console.log("第一组第一条:我的博客(http://www.ido321.com)");
12 12:
13 13:         console.log("第一组第二条:CSDN(http://blog.csdn.net/u011043843)");
14 14:
15 15:       console.groupEnd();
16 16:
17 17:       console.group("第二组信息");
18 18:
19 19:         console.log("第二组第一条:程序爱好者QQ群: 259280570");
20 20:
21 21:         console.log("第二组第二条:欢迎你加入");
22 22:
23 23:       console.groupEnd();
24 24:     </script>
25 25: </body>
26 26: </html>

 

  效果:

 

  四、查看对象的信息

 

  console.dir()可以显示一个对象所有的属性和方法。

1 1: <script type="text/javascript">
2 2:         var info = {
3 3:             blog:"http://www.ido321.com",
4 4:             QQGroup:259280570,
5 5:             message:"程序爱好者欢迎你的加入"
6 6:         };
7 7:         console.dir(info);
8 8: </script>

 

  效果:

 

  五、显示某个节点的内容

 

  console.dirxml()用来显示网页的某个节点(node)所包含的html/xml代码。

01 1: <!DOCTYPE html>
02  2: <html>
03  3: <head>
04  4:     <title>常用console命令</title>
05  5:     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
06  6: </head>
07  7: <body>
08  8:     <div id="info">
09  9:         <h3>我的博客:www.ido321.com</h3>
10 10:         <p>程序爱好者:259280570,欢迎你的加入</p>
11 11:     </div>
12 12:     <script type="text/javascript">
13 13:         var info = document.getElementById('info');
14 14:         console.dirxml(info);
15 15:     </script>
16 16: </body>
17 17: </html>

 

 

  六、判断变量是否是真

 

  console.assert()用来判断一个表达式或变量是否为真。如果结果为否,则在控制台输出一条相应信息,并且抛出一个异常。

1 1: <script type="text/javascript">
2 2:       var result = 1;
3 3:       console.assert( result );
4 4:       var year = 2014;
5 5:       console.assert(year == 2018 );
6 6: </script>

  1是非0值,是真;而第二个判断是假,在控制台显示错误信息

 

 

  七、追踪函数的调用轨迹。

 

  console.trace()用来追踪函数的调用轨迹。

01 1: <script type="text/javascript">
02  2: /*函数是如何被调用的,在其中加入console.trace()方法就可以了*/
03  3:   function add(a,b){
04  4:         console.trace();
05  5:     return a+b;
06  6:   }
07  7:   var x = add3(1,1);
08  8:   function add3(a,b){return add2(a,b);}
09  9:   function add2(a,b){return add1(a,b);}
10 10:   function add1(a,b){return add(a,b);}
11 11: </script>

  控制台输出信息:

 

  八、计时功能

  console.time()和console.timeEnd(),用来显示代码的运行时间。

1 1: <script type="text/javascript">
2    2:   console.time("控制台计时器一");
3    3:   for(var i=0;i<1000;i++){
4    4:     for(var j=0;j<1000;j++){}
5    5:   }
6    6:   console.timeEnd("控制台计时器一");
7    7: </script>

  运行时间是38.84ms

  九、console.profile()的性能分析

 

  性能分析(Profiler)就是分析程序各个部分的运行时间,找出瓶颈所在,使用的方法是console.profile()。

01 1: <script type="text/javascript">
02  2:       function All(){
03  3:             alert(11);
04  4:          for(var i=0;i<10;i++){
05  5:                 funcA(1000);
06  6:              }
07  7:         funcB(10000);
08  8:       }
09  9:
10 10:       function funcA(count){
11 11:         for(var i=0;i<count;i++){}
12 12:       }
13 13:
14 14:       function funcB(count){
15 15:         for(var i=0;i<count;i++){}
16 16:       }
17 17:
18 18:       console.profile('性能分析器');
19 19:       All();
20 20:       console.profileEnd();
21 21:     </script>

  输出如图

 一、显示信息的命令

  

01 1: <!DOCTYPE html>
02  2: <html>
03  3: <head>
04  4:     <title>常用console命令</title>
05  5:     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
06  6: </head>
07  7: <body>
08  8:     <script type="text/javascript">
09  9:         console.log('hello');
10 10:         console.info('信息');
11 11:         console.error('错误');
12 12:         console.warn('警告');
13 13:     </script>
14 14: </body>
15 15: </html>

  最常用的就是console.log了。

 

  二:占位符

 

  console上述的集中度支持printf的占位符格式,支持的占位符有:字符(%s)、整数(%d或%i)、浮点数(%f)和对象(%o)

1 <font face="Tahoma, Arial, Helvetica, snas-serif"><span style="font-size: 16.3799991607666px; white-space: normal;"><b></b></span></font>   1: <script type="text/javascript">
2    2:         console.log("%d年%d月%d日",2011,3,26);
3    3: </script>

 

  效果:

 

  三、信息分组

 

01 1: <!DOCTYPE html>
02  2: <html>
03  3: <head>
04  4:     <title>常用console命令</title>
05  5:     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
06  6: </head>
07  7: <body>
08  8:     <script type="text/javascript">
09  9:         console.group("第一组信息");
10 10:
11 11:         console.log("第一组第一条:我的博客(http://www.ido321.com)");
12 12:
13 13:         console.log("第一组第二条:CSDN(http://blog.csdn.net/u011043843)");
14 14:
15 15:       console.groupEnd();
16 16:
17 17:       console.group("第二组信息");
18 18:
19 19:         console.log("第二组第一条:程序爱好者QQ群: 259280570");
20 20:
21 21:         console.log("第二组第二条:欢迎你加入");
22 22:
23 23:       console.groupEnd();
24 24:     </script>
25 25: </body>
26 26: </html>

 

  效果:

 

  四、查看对象的信息

 

  console.dir()可以显示一个对象所有的属性和方法。

1 1: <script type="text/javascript">
2 2:         var info = {
3 3:             blog:"http://www.ido321.com",
4 4:             QQGroup:259280570,
5 5:             message:"程序爱好者欢迎你的加入"
6 6:         };
7 7:         console.dir(info);
8 8: </script>

 

  效果:

 

  五、显示某个节点的内容

 

  console.dirxml()用来显示网页的某个节点(node)所包含的html/xml代码。

01 1: <!DOCTYPE html>
02  2: <html>
03  3: <head>
04  4:     <title>常用console命令</title>
05  5:     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
06  6: </head>
07  7: <body>
08  8:     <div id="info">
09  9:         <h3>我的博客:www.ido321.com</h3>
10 10:         <p>程序爱好者:259280570,欢迎你的加入</p>
11 11:     </div>
12 12:     <script type="text/javascript">
13 13:         var info = document.getElementById('info');
14 14:         console.dirxml(info);
15 15:     </script>
16 16: </body>
17 17: </html>

 

 

  六、判断变量是否是真

 

  console.assert()用来判断一个表达式或变量是否为真。如果结果为否,则在控制台输出一条相应信息,并且抛出一个异常。

1 1: <script type="text/javascript">
2 2:       var result = 1;
3 3:       console.assert( result );
4 4:       var year = 2014;
5 5:       console.assert(year == 2018 );
6 6: </script>

  1是非0值,是真;而第二个判断是假,在控制台显示错误信息

 

 

  七、追踪函数的调用轨迹。

 

  console.trace()用来追踪函数的调用轨迹。

01 1: <script type="text/javascript">
02  2: /*函数是如何被调用的,在其中加入console.trace()方法就可以了*/
03  3:   function add(a,b){
04  4:         console.trace();
05  5:     return a+b;
06  6:   }
07  7:   var x = add3(1,1);
08  8:   function add3(a,b){return add2(a,b);}
09  9:   function add2(a,b){return add1(a,b);}
10 10:   function add1(a,b){return add(a,b);}
11 11: </script>

  控制台输出信息:

 

  八、计时功能

  console.time()和console.timeEnd(),用来显示代码的运行时间。

1 1: <script type="text/javascript">
2    2:   console.time("控制台计时器一");
3    3:   for(var i=0;i<1000;i++){
4    4:     for(var j=0;j<1000;j++){}
5    5:   }
6    6:   console.timeEnd("控制台计时器一");
7    7: </script>

  运行时间是38.84ms

  九、console.profile()的性能分析

 

  性能分析(Profiler)就是分析程序各个部分的运行时间,找出瓶颈所在,使用的方法是console.profile()。

01 1: <script type="text/javascript">
02  2:       function All(){
03  3:             alert(11);
04  4:          for(var i=0;i<10;i++){
05  5:                 funcA(1000);
06  6:              }
07  7:         funcB(10000);
08  8:       }
09  9:
10 10:       function funcA(count){
11 11:         for(var i=0;i<count;i++){}
12 12:       }
13 13:
14 14:       function funcB(count){
15 15:         for(var i=0;i<count;i++){}
16 16:       }
17 17:
18 18:       console.profile('性能分析器');
19 19:       All();
20 20:       console.profileEnd();
21 21:     </script>

  

 

 

原文链接:https://github.com/dwqs/blog/issues/32

posted @ 2016-08-26 20:53  jason_zhangz  阅读(332)  评论(0编辑  收藏  举报