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()输出栈信息

相关推荐
码云之上21 小时前
从一个截图函数到一个 npm 包——pdf-snapshot 的诞生记
前端·node.js·github
Kel1 天前
Pi Monorepo Stream Event Flow 深度分析
人工智能·架构·node.js
米丘1 天前
Connect 深度解析:Node.js 中间件框架的基石
javascript·http·node.js
yichudu1 天前
nodejs 介绍
node.js
Ztopcloud极拓云视角1 天前
Claude Code 源码泄露事件技术复盘:npm sourcemap 配置失误的完整分析
前端·npm·node.js
天下无贼!1 天前
【功能实现】基于Vue3+TS实现大文件分片上传
开发语言·javascript·node.js·vue·html5
zhensherlock1 天前
Protocol Launcher 系列:Agenda 优雅组织你的想法与日程
javascript·macos·ios·typescript·node.js·mac·ipad
吴声子夜歌1 天前
Node.js——Express详解(二)
node.js·express
Moshow郑锴1 天前
npm国内镜像加速之使用 nrm 工具(灵活切换,适合多环境)
前端·npm·node.js
吴声子夜歌1 天前
Node.js——Express详解(一)
node.js·express