Node.js 入门教程 12 使用 Node.js 输出到命令行
创始人
2024-02-18 01:22:22
0

Node.js 入门教程

Node.js官方入门教程

Node.js中文网

本文仅用于学习记录,不存在任何商业用途,如侵删

文章目录

      • Node.js 入门教程
      • 12 使用 Node.js 输出到命令行
          • 12.1 使用控制台模块的基础输出
          • 12.2 清空控制台
          • 12.3 元素计数
          • 12.4 打印堆栈踪迹
          • 12.5 计算耗时
          • 12.6 stdout 和 stderr
          • 12.7 为输出着色
          • 12.8 创建进度条

12 使用 Node.js 输出到命令行

12.1 使用控制台模块的基础输出

Node.js 提供了 console 模块,该模块提供了大量非常有用的与命令行交互的方法。

在这里插入图片描述

它基本上与浏览器中的 console 对象相同。

最基础、最常用的方法是 console.log(),该方法会打印传入到控制台的字符串。

如果传入对象,则它会呈现为字符串。

可以传入多个变量到 console.log,例如:

const x = 'x'
const y = 'y'
console.log(x, y)

在这里插入图片描述

Node.js 会全部打印出来。

也可以通过传入变量和格式说明符来格式化用语。

例如:

console.log('我的%s已经%d岁', '猫', 2)

在这里插入图片描述

  • %s 会格式化变量为字符串
  • %d 会格式化变量为数字
  • %i 会格式化变量为其整数部分
  • %o 会格式化变量为对象
console.log('%o', Number)

在这里插入图片描述

12.2 清空控制台

console.clear() 会清除控制台(其行为可能取决于所使用的控制台)。

在这里插入图片描述

12.3 元素计数

console.count() 是一个便利的方法。

使用以下代码:

const x = 1
const y = 2
const z = 3
console.count('x 的值为 ' + x + ' 且已经检查了几次?'
)
console.count('x 的值为 ' + x + ' 且已经检查了几次?'
)
console.count('y 的值为 ' + y + ' 且已经检查了几次?'
)

在这里插入图片描述

count 方法会对打印的字符串的次数进行计数,并在其旁边打印计数:

数苹果和橙子:

const oranges = ['橙子', '橙子']
const apples = ['苹果']
oranges.forEach(fruit => {console.count(fruit)
})
apples.forEach(fruit => {console.count(fruit)
})

在这里插入图片描述

12.4 打印堆栈踪迹

在某些情况下,打印函数的调用堆栈踪迹很有用,可以回答以下问题:如何到达代码的那一部分?

可以使用 console.trace() 实现:

const function2 = () => console.trace()
const function1 = () => function2()
function1()

在这里插入图片描述

打印堆栈踪迹。

12.5 计算耗时

可以使用 time()timeEnd() 轻松地计算函数运行所需的时间:

const doSomething = () => console.log('测试')
const measureDoingSomething = () => {console.time('doSomething()')//做点事,并测量所需的时间。doSomething()console.timeEnd('doSomething()')
}
measureDoingSomething()

在这里插入图片描述

12.6 stdout 和 stderr

console.log 非常适合在控制台中打印消息。 这就是所谓的标准输出(或称为 stdout)。

console.error 会打印到 stderr 流。

它不会出现在控制台中,但是会出现在错误日志中。

12.7 为输出着色

可以使用转义序列在控制台中为文本的输出着色。 转义序列是一组标识颜色的字符。

在这里插入图片描述

例如:

console.log('\x1b[33m%s\x1b[0m', '你好')

在这里插入图片描述

打印黄色的 你好

当然,这是执行此操作的底层方法。 为控制台输出着色的最简单方法是使用库。

Chalk 是一个这样的库,除了为其着色外,它还有助于其他样式的设置(例如使文本变为粗体、斜体或带下划线)。

在这里插入图片描述

先安装

npm install chalk

在这里插入图片描述

使用

const chalk = require('chalk')
console.log(chalk.yellow('你好'))

在这里插入图片描述

可以看到报错了,开始谷歌,说是版本高了

在这里插入图片描述

降成4.1

在这里插入图片描述

再试一次

在这里插入图片描述

OK。

与尝试记住转义代码相比,使用 chalk.yellow 方便得多,并且代码更具可读性。

12.8 创建进度条

Progress 是一个很棒的软件包,可在控制台中创建进度条。 使用 npm install progress 进行安装。

在这里插入图片描述

在这里插入图片描述

以下代码段会创建一个 10 步的进度条,每 100 毫秒完成一步。 当进度条结束时,则清除定时器:

const ProgressBar = require('progress')const bar = new ProgressBar(':bar', { total: 10 })
const timer = setInterval(() => {bar.tick()if (bar.complete) {clearInterval(timer)}
}, 100)

在这里插入图片描述

可爱捏。

相关内容

热门资讯

徐奇渊:扩内需与对外政策紧密相... 近日,中国海关总署发布了一组数据令人关注:2025年前11个月,我国货物贸易顺差达到1.08万亿美元...
46岁上海独居女子不幸离世,官... 居住在上海虹口区46岁的蒋女士因突发脑溢血于今年10月入院,远亲吴先生与其公司共同垫付了医药费,但她...
威海市汽车以旧换新补贴政策调整... 根据稳妥有序开展消费品以旧换新工作统一部署,经研究决定,对我市汽车以旧换新补贴政策进行调整。现将有关...
动物学家、律师、创作者都pic... 12月21日,在2025 ThinkPad黑FUN礼现场,三名专业领域用户用真实案例诠释了Think...
从拒赔到和解:涉外货运保险理赔... 近日,国家金融监管总局、最高人民法院遴选出6个具有典型性、示范性的金融领域纠纷多元化解案例,12月1...
湖北大冶一男子当街拦车砸玻璃,... 大象新闻2025-12-21 16:21:41 12月20日,湖北大冶市网民发视频称,一名男子在新冶...
韩媒曝尹锡悦夫妇下周将被同时起... 据韩联社21日报道,负责调查韩国前总统尹锡悦夫人金建希弊案的独立检察组(独检组)将于下周同时对尹锡悦...
大冶一男子拦停轿车打砸!大冶公... 原标题:大冶公安查处一起妨碍交通工具正常行驶案件 2025年12月20日15时许,我辖区居民刘某(男...
化解纠纷12215件 银行点赞... 中国民生银行信用卡中心昆明分中心向昆明市官渡区人民法院立案庭立案窗口、矛盾纠纷化解中心以及保全团队赠...
政治思想工作条例解读,政治思想... 政治思想工作条例解读,政治思想工作条例最新版全文 政治思想工作条例最新版全文解读:照亮前行之路的“灯...