打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
日志库 winston 的学习笔记 - logger.info 打印到控制台上的实现原理
if (process.env.NODE_ENV !== 'production') {
    logger.add(new winston.transports.Console({
      format: winston.format.combine(
        winston.format.colorize({ all: true }),
        winston.format.simple()
    )}));
}

上述代码的含义是,如果当前 Node.js 执行环境不是生产环境,则将 winston 的输出,打印到控制台上。

_stream_readable.js 抛出 data 事件:

读取事件处理函数:

console 对应的 event handler:

transformed:

console 有专门对应的 transport 实现文件,位于 console.js 内:

从 data 字符串能看出在 console 打印彩色字符串的实现方式:

并没有像我想象的那样,执行到 82 行的 console.log

console 对象的 _stdout 属性,在 internal 这个 constructor.js 里注入:

这个 writeUtf8String 函数,是原生 native API:

位于 Node.js 源代码 的 internal/stream_base_common.js 内部:

writeUtf8String

stream_base_commons.js 文件位置如下:

https://github.com/nodejs/node/tree/master/lib/internal

native 实现:

https://github.com/nodejs/node/blob/master/lib/internal/stream_base_commons.js

this[kFs].write

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
Node.js基础入门第六天
Node.js fs 模組 APIs 的三種類型
Node
初学者学习 JavaScript – JS 基础知识手册正式版
使用 VS Code 调试 Node.js 的超简单方法
Javascript输入输出语句
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服