91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

nodejs 終端打印進度條實例代碼

發布時間:2020-09-03 14:04:50 來源:腳本之家 閱讀:215 作者:parksben 欄目:web開發

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 終端打印進度條實例代碼

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

连江县| 南平市| 和林格尔县| 沁源县| 灌阳县| 黄浦区| 贞丰县| 涟源市| 平山县| 新宁县| 建水县| 平谷区| 上蔡县| 岐山县| 黄山市| 兴山县| 汉源县| 惠州市| 东兰县| 罗甸县| 贡觉县| 浦县| 田阳县| 成都市| 临沂市| 永康市| 万荣县| 普安县| 泰安市| 昆明市| 灌云县| 武威市| 永春县| 色达县| 靖江市| 资阳市| 嘉义县| 磐安县| 南阳市| 夏邑县| 宁陵县|