nodejs终端打印进度条实例代码

  

<强> 1。场景导入
  

  

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

  

<强> 2。基本原理
  

  

首先,在终端打印出文本是件比较容易的事情。那么使用简单的文本和符号,就够自己拼凑出命令行的效果(下面例子):

  

文件已上传:43.60%█████████████████████& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;& # 9617;150/344
  

  

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

  

这里,我将打印命令行的方法构造成一个工具模块<代码>进度条。js代码>      //这里用到一个很实用的npm模块,用以在同一行打印文本   var的路程=要求(single-line-log) .stdout;//封装的ProgressBar工具   函数ProgressBar(描述、bar_length) {//两个基本参数(属性)   描述this.description=| |“进步”;//命令行开头的文字信息   这一点。长度=bar_length | | 25;//进度条的长度(单位:字符),默认设为25//刷新进度条图案,文字的方法   这一点。渲染=函数(选择){   var=(opts.completed/opts.total)百分比.toFixed (4);//计算进度(子任务的完成数除以总数)   var cell_num=数学。地板(* this.length百分比);//计算需要多少个█符号来拼凑图案//拼接黑色条   var="细胞;   我(var=0; i< cell_num;我+ +){   细胞+=皑€”;   }//拼接灰色条   空var=";   我(var=0; i< this.length-cell_num;我+ +){   空+=' & # 9617;;   }//拼接最终文本   var cmdText=this.description +“:”+(100 *百分比).toFixed(2) +‘%’+电池+空+ " " + opts.completed +‘/? opts.total;//在单行输出文本   跋涉(cmdText);   };   }//模块导出   模块。出口=ProgressBar;      之前      

<强> 3。运行起来
  

  

基于上面的实现,先说一下这个<代码>进度条。js代码的用法:

     //引入工具模块   var ProgressBar=要求('/progress_bar。');//初始化一个进度条长度为50的ProgressBar实例   var pb=new ProgressBar(“下载进度”,50);//这里只是一个pb的使用示例,不包含任何功能   var num=0,总=200;   函数下载(){   如果(num & lt;=总){//更新进度条   pb。呈现({完成:num总:总});      num + +;   setTimeout(函数(){   下载();   },500)   }   }   下载();      之前      

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

  

 nodejs终端打印进度条实例代码

  

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

nodejs终端打印进度条实例代码