nodejs 終端打印進(jìn)度條

1. 場景導(dǎo)入

當(dāng)我們對(duì)大量文件進(jìn)行批量處理的時(shí)候(例如:上傳/下載、保存、編譯等),常常希望知道當(dāng)前進(jìn)展如何,或者失敗(成功)的任務(wù)有多少;當(dāng)我們的代碼或程序已經(jīng)發(fā)布,用戶在執(zhí)行安裝的過程中,一個(gè)合適的(終端/命令行)進(jìn)度條可以準(zhǔn)確反映安裝的步驟和進(jìn)程,提升程序的可用性,一定程度緩解用戶在等待中的煩惱……

2. 基本原理

首先,在終端打印出文本是件比較容易的事情。
那么使用簡單的文本和符號(hào),就夠自己拼湊出命令行的效果(下面例子):

文件已上傳: 43.60% █████████████████████????????????????????????????? 150/344

當(dāng)然,進(jìn)度條的效果可以根據(jù)需要自己設(shè)計(jì)啦,我這里只是給大家一個(gè)參考。

這里,我將打印命令行的方法構(gòu)造成一個(gè)工具模塊 progress-bar.js,具體實(shí)現(xiàn)如下 :-)

// 這里用到一個(gè)很實(shí)用的 npm 模塊,用以在同一行打印文本
var slog = require('single-line-log').stdout;

// 封裝的 ProgressBar 工具
function ProgressBar(description, bar_length){
  // 兩個(gè)基本參數(shù)(屬性)
  this.description = description || 'Progress';       // 命令行開頭的文字信息
  this.length = bar_length || 25;                     // 進(jìn)度條的長度(單位:字符),默認(rèn)設(shè)為 25

  // 刷新進(jìn)度條圖案、文字的方法
  this.render = function (opts){
    var percent = (opts.completed / opts.total).toFixed(4);    // 計(jì)算進(jìn)度(子任務(wù)的 完成數(shù) 除以 總數(shù))
    var cell_num = Math.floor(percent * this.length);             // 計(jì)算需要多少個(gè) █ 符號(hào)來拼湊圖案

    // 拼接黑色條
    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);
  };
}

// 模塊導(dǎo)出
module.exports = ProgressBar;

3. Run 起來

基于上面的實(shí)現(xiàn),先說一下這個(gè) progress-bar.js 的用法:

// 引入工具模塊
var ProgressBar = require('./progress_bar');

// 初始化一個(gè)進(jìn)度條長度為 50 的 ProgressBar 實(shí)例
var pb = new ProgressBar('下載進(jìn)度', 50);

// 這里只是一個(gè) pb 的使用示例,不包含任何功能
var num = 0, total = 200;
function downloading() {
  if (num <= total) {
    // 更新進(jìn)度條
    pb.render({ completed: num, total: total });

    num++;
    setTimeout(function (){
      downloading();
    }, 500)
  }
}
downloading();

run 一下上面的代碼,執(zhí)行效果如下:

如有幫助,請(qǐng)看官記得點(diǎn)贊或者打賞下下 ( _ )
原創(chuàng)文章,轉(zhuǎn)載請(qǐng)注明出處

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 15,033評(píng)論 4 61
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 178,725評(píng)論 25 709
  • 朱宇凱,這是我第二次寫日志寫日志關(guān)于生日。你之前老是鬧騰要我寫一篇滿滿是花言巧語的文章送你,我本來打算某個(gè)特別的日...
    憂傷的紫兔子閱讀 387評(píng)論 0 0
  • 關(guān)于作者 凱倫·伯格是美國溝通專家、演講大師、專業(yè)發(fā)言人。 關(guān)于本書 凱倫·伯格結(jié)合自己多年的研究經(jīng)驗(yàn),從大量真實(shí)...
    子曰葡萄閱讀 789評(píng)論 0 0
  • 書桌上,父親仔細(xì)的看著大學(xué)名冊(cè),皺眉問道:“你覺得你可以考多少分呢?”我在一旁撇了撇嘴:“不知道?!薄澳愎烙?jì)一下嘛...
    白肥大叔兔閱讀 311評(píng)論 0 1

友情鏈接更多精彩內(nèi)容