nodejs 终端打印进度条

作者: 彭逸之 | 来源:发表于2017-04-21 19:34 被阅读1129次

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_num;i++) {
      cell += '█';
    }

    // 拼接灰色条
    var empty = '';
    for (var i=0;i<this.length-cell_num;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 一下上面的代码,执行效果如下:

如有帮助,请看官记得点赞或者打赏下下 ( _ )
原创文章,转载请注明出处

相关文章

  • nodejs 终端打印进度条

    1. 场景导入 当我们对大量文件进行批量处理的时候(例如:上传/下载、保存、编译等),常常希望知道当前进展如何,或...

  • sys模块

    打印进度条 进度条的效果 [# ][## ][### ...

  • gulp安装

    ,目前我使用gulp的目的:css压缩,js压缩合并 1.nodejs安装: 在终端输入node -v回车打印出n...

  • Express 入门

    安装 NodeJS 安装 NodeJS 在终端中,使用下面的命令安装 NodeJS: curl --silent ...

  • 高明1025笔记

    终端和nodejs的io交互(io是input和output,输入和输出) 终端和io交互需要引入一个nodejs...

  • JSPM安装

    下载安装: http://nodejs.cn/ https://nodejs.org/en/ 终端输入 安装: s...

  • Mac 系统配置Vue开发环境

    首先安装nodejs 终端输入:brew install nodejs 或者直接官网手动安装。 node -v 查...

  • 蜂巢云打印机是什么意思?免费吗?如何自动接单?

    佳博智能蜂巢云打印机终端号: 问:什么是佳博智能蜂巢云打印机“终端号”? 答:佳博智能蜂巢云打印机“终端号”是蜂巢...

  • 安装 Appium for Mac

    1.安装appium 1.通过终端安装: 安装nodejs,下载地址:https://nodejs.org/en/...

  • 安装vue-cli

    先去nodejs.org下载nodejs。然后在终端上输入npm install -g @vue/cli进行安装n...

网友评论

    本文标题:nodejs 终端打印进度条

    本文链接:https://www.haomeiwen.com/subject/tuzdzttx.html