Node.js的控制台console

新书速览|Vue.js+Node.js全栈开发实战-CSDN博客

《Vue.js+Node.js全栈开发实战(第2版)(Web前端技术丛书)》(王金柱)【摘要 书评 试读】- 京东图书 (jd.com)

利用好Node.js提供的console控制台和debug,可以有效地辅助开发和定位bug。在Node.js中,console代表控制台,可以通过console对象的各种方法向控制台进行标准输出。

3.3.1 console对象下的各种方法

在REPL交互式运行环境中输入console,可以看到console对象下各种方法组成的一个数组,如图3.7所示。

图3.7 console对象的方法

3.3.2 console.log()方法

console.log()方法用于标准输出流的输出,也就是在命令行中显示一行信息,例如:

console.log('node.js is powerful')

无论是在REPL环境中运行这行代码,还是作为Node.js文件执行这行代码,都可以看到在命令行中输出"node.js is powerful"字样。

console.log()方法并没有对参数的个数进行限制,当传递多个参数时,命令行输出将以空格分隔这些参数,例如:

console.log('node.js','is','powerful');

运行之后,同样会在命令行输出"node.js is powerful"字样,这3个单词也依旧是以空格分隔开来的。

console.log()方法也可以利用占位符来定义输出的格式。例如,%d表示数字,%s表示字符串。

提示:如果需要对后面的多个参数都定义格式,就要逐个进行设置,并且输出时将不会以空格分隔;如果没有预定义格式,将会正常输出。

示例代码如下:

【代码3-7】

01  console.log('%s%s', 'node.js', 'is', 'powerful');
02  // node.jsis powerful
03  console.log('%s%s%s', 'node.js', 'is', 'powerful');
04  // node.jsispowerful
05  console.log('%d', 'node.js');
06  // NaN
07  console.log('%d', 'node.js', 'is', 'powerful');
08  // NaN is powerul

需要注意,在这一段代码中,当使用%d占位符后,如果对应的参数不是数字,则控制台将会输出"NaN"。

3.3.3 console.info()、console.warn()和console.error()方法

console.info()、console.warn()以及console.error()方法的使用和console.log()一致,将3.3.2小节的代码换成console.info()、console.warn()、console.error()方法,将得到同样的结果:

【代码3-8】

01  console.warn('%s%s', 'node.js', 'is', 'powerful');
02  // node.jsis powerful
03  console.warn('%s%s%s', 'node.js', 'is', 'powerful');
04  // node.jsispowerful
05  console.info('%d', 'node.js');
06  // NaN
07  console.info('%d', 'node.js', 'is', 'powerful');
08  // NaN is powerul
09  console.error('%d', 'node.js');
10  // NaN
11  console.error('%d', 'node.js', 'is', 'powerful');
12  // NaN is powerul

3.3.4 console.dir()方法

console.dir()方法用于将一个对象的信息输出到命令行。如下代码将定义一个简单的对象。

【代码3-9】

01  const obj = {
02  name: 'node.js',
03      get: function() {
04        console.log('get');
05      },
06      set: function() {
07        console.log('set');
08      }
09  }
10  console.dir(obj);

在REPL交互式运行环境中运行这段代码,可以看到命令行中输出这个对象的信息,如图3.8所示。

图3.8 console.dir()方法输出对象信息

3.3.5 console.time()和console.timeEnd()方法

console.time()和console.timeEnd()方法主要用于统计一段代码的运行时间。console.time()方法置于代码起始处,console.timeEnd()方法置于代码结尾处。只需要向这两个方法传递同一个参数,就可以在命令行中输出以毫秒计的代码运行时间。如下代码统计了两个循环执行后的时间以及各个循环分别使用的时间。

【代码3-10】

01  console.time('total time');
02  console.time('time1');
03  for(var i =0; i< 10000; i++) {
04  }
05  console.timeEnd('time1');
06  console.time('time2');
07  for(var i =0; i< 100000; i++) {
08  }
09  console.timeEnd('time2');
10  console.timeEnd('total time');

将这段代码保存为名为"time.js"的文件。利用node time命令运行这个文件,可以在命令行中看到各个循环的使用时间统计,如图3.9所示。

图3.9 各个循环使用的时间统计

3.3.6 console.trace()方法

console.trace()用于输出当前位置的栈信息,可以向console.trace()方法传递任意字符串作为标志,类似于console.time()中的参数。在REPL交互式运行环境中执行以下代码:

console.trace('trace');

可以看到此处的栈信息已经在命令行中输出,如图3.10所示。

图3.10 console.trace()输出栈信息

相关推荐
理想不理想v1 小时前
webpack最基础的配置
前端·webpack·node.js
南城巷陌4 小时前
JWT认证机制在Node.js中的详细阐述
node.js·jwt认证机制·前端安全认证
理想不理想v6 小时前
node.js的简单示例
node.js
yrldjsbk6 小时前
使用Node.js搭配express框架快速构建后端业务接口模块Demo
node.js·express
维李设论6 小时前
Node.js的Web服务在Nacos中的实践
前端·spring cloud·微服务·eureka·nacos·node.js·express
CodeChampion8 小时前
60.基于SSM的个人网站的设计与实现(项目 + 论文)
java·vue.js·mysql·spring·elementui·node.js·mybatis
Domain-zhuo8 小时前
如何利用webpack来优化前端性能?
前端·webpack·前端框架·node.js·ecmascript
理想不理想v8 小时前
webpack如何自定义插件?示例
前端·webpack·node.js
斜杠poven12 小时前
为什么加try catch 不会 block 进程?
前端·javascript·node.js
韩俊强1 天前
使用Docker部署一个Node.js项目
docker·容器·node.js