nodejs 終端打印進(jìn)度條實例代碼
1. 場景導(dǎo)入
當(dāng)我們對大量文件進(jìn)行批量處理的時候(例如:上傳/下載、保存、編譯等),常常希望知道當(dāng)前進(jìn)展如何,或者失敗(成功)的任務(wù)有多少;當(dāng)我們的代碼或程序已經(jīng)發(fā)布,用戶在執(zhí)行安裝的過程中,一個合適的(終端/命令行)進(jìn)度條可以準(zhǔn)確反映安裝的步驟和進(jìn)程,提升程序的可用性,一定程度緩解用戶在等待中的煩惱……
2. 基本原理
首先,在終端打印出文本是件比較容易的事情。那么使用簡單的文本和符號,就夠自己拼湊出命令行的效果(下面例子):
文件已上傳: 43.60% █████████████████████░░░░░░░░░░░░░░░░░░░░░░░░░░░░░ 150/344
當(dāng)然,進(jìn)度條的效果可以根據(jù)需要自己設(shè)計啦,我這里只是給大家一個參考。
這里,我將打印命令行的方法構(gòu)造成一個工具模塊 progress-bar.js,具體實現(xiàn)如下 :-)
// 這里用到一個很實用的 npm 模塊,用以在同一行打印文本
var slog = require('single-line-log').stdout;
// 封裝的 ProgressBar 工具
function ProgressBar(description, bar_length){
// 兩個基本參數(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ìn)度(子任務(wù)的 完成數(shù) 除以 總數(shù))
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);
};
}
// 模塊導(dǎo)出
module.exports = ProgressBar;
3. Run 起來
基于上面的實現(xiàn),先說一下這個 progress-bar.js 的用法:
// 引入工具模塊
var ProgressBar = require('./progress_bar');
// 初始化一個進(jìn)度條長度為 50 的 ProgressBar 實例
var pb = new ProgressBar('下載進(jìn)度', 50);
// 這里只是一個 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í)行效果如下:

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
詳解Node.js中path模塊的resolve()和join()方法的區(qū)別
這篇文章主要介紹了詳解Node.js中path模塊的resolve()和join()方法的區(qū)別,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10
Nuxt配合Node在實際生產(chǎn)中的應(yīng)用詳解
這篇文章主要介紹了Nuxt配合Node在實際生產(chǎn)中的應(yīng)用詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08
Windows中徹底刪除Node.js環(huán)境(以及npm)的方法
本文詳細(xì)介紹了如何在Windows電腦中徹底刪除Node.js環(huán)境,包括查找安裝路徑、使用控制面板卸載以及手動刪除殘留文件夾2025-01-01

