Node.js API详解之 console模块用法详解
本文实例讲述了Node.js API详解之 console模块用法。分享给大家供大家参考,具体如下:
console模块简介
说明:
console 模块提供了一个简单的调试控制台,类似于 Web 浏览器提供的 JavaScript 控制台。
console 模块导出了两个特定的组件:
一个 Console 类,包含 console.log() 、 console.error() 和 console.warn() 等方法,可以被用于写入到任何 Node.js 流。
一个全局的 console 实例,可被用于写入到 process.stdout 和 process.stderr。
全局的 console 使用时无需调用 require('console')。
demo:
const fs = require('fs'); /* 全局console */ console.log('你好世界'); // 输出: 你好世界 console.log('你好%s', '世界'); // 输出: 你好世界 console.error(new Error('错误信息')); // Error: 错误信息 // at Object. (/Users/xiaoqiang/Documents/work/demo/NodeApi/app.js:7:15) // at Module._compile (module.js:569:30) // at Object.Module._extensions..js (module.js:580:10) // at Module.load (module.js:503:32) // at tryModuleLoad (module.js:466:12) // at Function.Module._load (module.js:458:3) // at Function.Module.runMain (module.js:605:10) // at startup (bootstrap_node.js:158:16) // at bootstrap_node.js:575:3 const name = '描述'; console.warn(`警告:${name}`); //警告:描述 /* 全局console */ const out = fs.createWriteStream('./stdout.log'); const err = fs.createWriteStream('./stderr.log'); const myConsole = new console.Console(out, err); myConsole.log('你好世界'); // 打印: '你好世界'到 stdout.log myConsole.log('你好%s', '世界'); // 打印: '你好世界'到 stdout.log myConsole.error(new Error('错误信息')); // 打印: [Error: 错误信息]到 stderr.log const name = '描述'; myConsole.warn(`警告${name}`); //打印: '警告描述' 到 stderr.log
Console 类
说明:
Console 类可用于创建一个具有可配置的输出流的简单记录器,
可以通过require('console').Console
或console.Console
使用
demo:
const { Console } = require('console'); const { Console } = console;
new Console(stdout[, stderr])
说明:
通过传入一个或两个可写流实例,创建一个新的 Console 对象
stdout:一个可写流,用于打印日志或输出信息。
stderr: 用于输出警告或错误。
如果没有传入 stderr ,则警告或错误输出会被发送到 stdout
全局的 console 是一个特殊的 Console 实例,
它的输出会发送到 process.stdout 和 process.stderr
demo:
const { Console } = require('console'); const fs = require('fs'); const output = fs.createWriteStream('./stdout.log'); const errorOutput = fs.createWriteStream('./stderr.log'); const logger = new Console(output, errorOutput); // 像 console 一样使用 logger.log('name: %s', 'xiaoqiang'); //stdout.log 中打印: name: xiaoqiang
console.assert(value[, message][, …args])
说明:
一个简单的断言测试,验证 value 是否为真。
value:断言条件,如果不为真,则抛出 AssertionError
message:如果提供了 message,则使用 util.format() 格式化并作为错误信息使用。
区别于浏览器的console.assert(),Node中的assert()如果断言非真的话会抛出异常终止程序。
demo:
const output = fs.createWriteStream('./stdout.log'); const errorOutput = fs.createWriteStream('./stderr.log'); const logger = new Console(output, errorOutput); logger.assert(false, 'Whoops %s', 'didn\'t work') // AssertionError [ERR_ASSERTION]: Whoops didn't work
console.clear()
说明:
当 stdout 是一个 TTY 时,调用 console.clear() 将尝试清除 TTY。
当 stdout 不是一个TTY时,该方法什么都不做。
console.count([label])
说明:
维护一个指定名称的内部计数器, 并且输出该名称调用 console.count() 的次数。
label:计数器名称
demo:
> console.count() default: 1 undefined > console.count('default') default: 2 undefined > console.count('abc') abc: 1 undefined > console.count('xyz') xyz: 1 undefined > console.count('abc') abc: 2 undefined > console.count() default: 3 undefined
console.countReset([label = 'default'])
说明:
重置指定 label 的内部计数器。
label:计数器的名称, 默认为 'default'。
demo:
> console.count('abc'); abc: 1 undefined > console.countReset('abc'); undefined > console.count('abc'); abc: 1 undefined >
console.dir(obj[, options])
说明:
在 obj 上使用 util.inspect() 并打印结果字符串到 stdout,
util.inspect() 方法返回 object 的字符串表示,主要用于调试。
showHidden:如果为 true,则该对象中的不可枚举属性和 symbol 属性也会显示。默认为 false。
depth: 告诉 util.inspect() 函数当格式化对象时要递归多少次。 默认为 2。 设为 null 可无限递归。
colors: 如果为 true,则输出会带有 ANSI 颜色代码。 默认为 false。 颜色是可定制的,
demo:
console.dir(console) // Console { // log: [Function: bound consoleCall], // info: [Function: bound consoleCall], // warn: [Function: bound consoleCall], // error: [Function: bound consoleCall], // dir: [Function: bound consoleCall], // time: [Function: bound consoleCall], // timeEnd: [Function: bound consoleCall], // trace: [Function: bound consoleCall], // assert: [Function: bound consoleCall], // Console: [Function: Console], // debug: [Function: debug], // dirxml: [Function: dirxml], // table: [Function: table], // group: [Function: group], // groupCollapsed: [Function: groupCollapsed], // groupEnd: [Function: groupEnd], // clear: [Function: clear], // count: [Function: count], // markTimeline: [Function: markTimeline], // profile: [Function: profile], // profileEnd: [Function: profileEnd], // timeline: [Function: timeline], // timelineEnd: [Function: timelineEnd], // timeStamp: [Function: timeStamp] }
console.error([data][, …args])
说明:
打印到 stderr,并带上换行符。 可以传入多个参数。
demo:
console.error('error: %d', 0x100008); //error: 1048584
console.group([…label])
说明:
将后续行的缩进增加两个空格。
demo:
console.groupCollapsed()
说明:
console.group()的一个别名.
console.groupEnd()
说明:
将后续行的缩进减少两个空格。与console.group()搭配使用。
console.info([data][, …args])
说明:
console.info() 函数是 console.log() 的一个别名。
demo:
console.info('name: %s', 'xiaoqiang');s //name: xiaoqiang
console.log([data][, …args])
说明:
打印到 stdout,并带上换行符。
demo:
console.log('name: %s', 'xiaoqiang'); //name: xiaoqiang console.log('name:', 'xiaoqiang'); //name: xiaoqiang
console.time(label)
说明:
启动一个定时器,用以计算一个操作的持续时间。
定时器有一个唯一的 label 标识。
当调用 console.timeEnd() 时,可以使用相同的 label 来停止定时器,
并以毫秒为单位将持续时间输出到 stdout。 定时器持续时间精确到亚毫秒。
demo:
console.time('run time'); for (var i = 100000; i >= 0; i--) {} console.timeEnd('run time'); //run time: 0.718ms
console.timeEnd(label)
说明:
停止之前通过调用 console.time() 启动的定时器,并打印结果到 stdout
console.trace([message][, …args])
说明:
打印字符串 'Trace :' 到 stderr ,并通过 util.format() 格式化消息堆栈打印代码踪迹。
用以跟踪代码的当前位置。
demo:
console.trace('run time Error'); // Trace: run time Error // at Object. (/Users/xiaoqiang/Documents/work/demo/NodeApi/app.js:5:9) // at Module._compile (module.js:569:30) // at Object.Module._extensions..js (module.js:580:10) // at Module.load (module.js:503:32) // at tryModuleLoad (module.js:466:12) // at Function.Module._load (module.js:458:3) // at Function.Module.runMain (module.js:605:10) // at startup (bootstrap_node.js:158:16) // at bootstrap_node.js:575:3
console.warn([data][, …args])
说明:
console.warn()
函数是console.error()
的一个别名。
希望本文所述对大家node.js程序设计有所帮助。
相关文章
- 这篇文章主要介绍了WebStorm无法正确识别Vue3组合式API的解决方案,帮助大家更好的理解和学习使用vue框架,感兴趣的朋友可以了解下...2021-02-18
- 这篇文章主要介绍了浅谈vue2的$refs在vue3组合式API中的替代方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-04-18
- 这次文章要给大家介绍的是node.JS md5加密中文与php结果不一致怎么办,不知道具体解决办法的下面跟小编一起来看看。 因项目需要,需要Node.js与PHP做接口调用,发现nod...2017-07-06
- 使用require('crypto')调用加密模块。加密模块需要底层系统提供OpenSSL的支持。它提供了一种安全凭证的封装方式,可以用于HTTPS安全网络以及普通HTTP连接。该模块还提供了一套针对OpenSSL的hash(哈希),hmac(密钥哈希),cipher...2014-06-07
- 1.什么是异步编程? 异步编程是指由于异步I/O等因素,无法同步获得执行结果时, 在回调函数中进行下一步操作的代码编写风格,常见的如setTimeout函数、ajax请求等等。示例: for (var i = 1; i <= 3; i++) {setTimeout(functi...2015-10-23
- 本文介绍基于nodejs+express+art-template的留言板功能。包含列表界面、添加界面和发送留言功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-21
安装使用Mongoose配合Node.js操作MongoDB的基础教程
这篇文章主要介绍了安装使用Mongoose来让Node.js操作MongoDB的基础教程,前端js+后端node+js操作MongoDB正是所谓最流行的一种JavaScript全栈开发方案,需要的朋友可以参考下...2016-03-03- 这篇文章主要为大家详细介绍了node.js从数据库获取数据的具体代码,nodejs可以获取具体某张数据表信息,感兴趣的朋友可以参考一下...2016-05-09
- 这篇文章介绍的是一个小技巧来获取node.js项目根目录,这个技巧非常实用。有需要的朋友们可以参考借鉴,下面来一起看看吧。...2016-10-02
- 这篇文章主要帮助大家理解JavaScript中worker事件api,对worker事件api有一个深刻了解,感兴趣的小伙伴们可以参考一下...2015-12-27
- 这篇文章主要介绍了如何使用 JavaScript 操作浏览器历史记录 API,帮助大家更好的理解和使用JavaScript,感兴趣的朋友可以了解下...2020-11-24
- 在日常开发中,总会接触到各种接口,前后端数据传输接口,第三方业务平台接口,下面这篇文章主要给大家介绍了关于如何设计一个安全的API接口的相关资料,需要的朋友可以参考下...2021-08-12
- post请求:复制代码 代码如下: request.post('/api/pet') .end(function(resp,err){ if (resp.body.status===200) { alert('yay got ' + JSON.stringify(res.body)); } else { return nex...2015-03-15
C# Windows API应用之基于GetDesktopWindow获得桌面所有窗口句柄的方法
这篇文章主要介绍了C# Windows API应用之基于GetDesktopWindow获得桌面所有窗口句柄的方法,结合实例形式分析了GetDesktopWindow函数用于获取窗口句柄的具体使用方法与相关注意事项,需要的朋友可以参考下...2020-06-25- 这篇文章主要介绍了node.js和Deno的区别,对deno感兴趣的同学,可以参考下...2021-04-27
- 这篇文章主要介绍了vue设置全局访问接口API地址操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-08-14
- 这篇文章主要介绍了Node.js之http模块的用法,对Node.js感兴趣的同学,可以参考下...2021-04-25
- 这篇文章主要介绍了node.js如何操作MySQL数据库,帮助大家更好的进行web开发,感兴趣的朋友可以了解下...2020-10-29
- 这篇文章主要介绍了Vue常用API、高级API的相关总结,帮助大家更好的理解和学习使用vue框架,感兴趣的朋友可以了解下...2021-02-04
- 这篇文章主要为大家详细介绍了三种Node.js写文件的方式,感兴趣的小伙伴们可以参考一下...2016-03-10