node打印服务器响应时间,nodejs 终端打印进度条

1. 场景导入

当我们对大量文件进行批量处理的时候(例如:上传/下载、保存、编译等),常常希望知道当前进展如何,或者失败(成功)的任务有多少;当我们的代码或程序已经发布,用户在执行安装的过程中,一个合适的(终端/命令行)进度条可以准确反映安装的步骤和进程,提升程序的可用性,一定程度缓解用户在等待中的烦恼……

2. 基本原理

首先,在终端打印出文本是件比较容易的事情。

那么使用简单的文本和符号,就够自己拼凑出命令行的效果(下面例子):

文件已上传: 43.60% █████████████████████░░░░░░░░░░░░░░░░░░░░░░░░░░░░░ 150/344

当然,进度条的效果可以根据需要自己设计啦,我这里只是给大家一个参考。

这里,我将打印命令行的方法构造成一个工具模块 progress-bar.js,具体实现如下 :-)

// 这里用到一个很实用的 npm 模块,用以在同一行打印文本

var slog = require('single-line-log').stdout;

// 封装的 ProgressBar 工具

function ProgressBar(description, bar_length){

// 两个基本参数(属性)

this.description = description || 'Progress'; // 命令行开头的文字信息

this.length = bar_length || 25; // 进度条的长度(单位:字符),默认设为 25

// 刷新进度条图案、文字的方法

this.render = function (opts){

var percent = (opts.completed / opts.total).toFixed(4); // 计算进度(子任务的 完成数 除以 总数)

var cell_num = Math.floor(percent * this.length); // 计算需要多少个 █ 符号来拼凑图案

// 拼接黑色条

var cell = '';

for (var i=0;i

cell += '█';

}

// 拼接灰色条

var empty = '';

for (var i=0;i

empty += '░';

}

// 拼接最终文本

var cmdText = this.description + ': ' + (100*percent).toFixed(2) + '% ' + cell + empty + ' ' + opts.completed + '/' + opts.total;

// 在单行输出文本

slog(cmdText);

};

}

// 模块导出

module.exports = ProgressBar;

3. Run 起来

基于上面的实现,先说一下这个 progress-bar.js 的用法:

// 引入工具模块

var ProgressBar = require('./progress_bar');

// 初始化一个进度条长度为 50 的 ProgressBar 实例

var pb = new ProgressBar('下载进度', 50);

// 这里只是一个 pb 的使用示例,不包含任何功能

var num = 0, total = 200;

function downloading() {

if (num <= total) {

// 更新进度条

pb.render({ completed: num, total: total });

num++;

setTimeout(function (){

downloading();

}, 500)

}

}

downloading();

run 一下上面的代码,执行效果如下:

00d8f71d367d

如有帮助,请看官记得点赞或者打赏下下 ( _ )

原创文章,转载请注明出处

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值