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


Posted in NodeJs onApril 22, 2017

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 终端打印进度条实例代码

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

NodeJs 相关文章推荐
用nodejs写的一个简单项目打包工具
May 11 NodeJs
NodeJS url验证(url-valid)的使用方法
Nov 18 NodeJs
Nodejs中session的简单使用及通过session实现身份验证的方法
Feb 04 NodeJs
NodeJs——入门必看攻略
Jun 27 NodeJs
NodeJS使用formidable实现文件上传
Oct 27 NodeJs
详解nodejs的express如何自动生成项目框架
Jul 12 NodeJs
nodejs socket服务端和客户端简单通信功能
Sep 14 NodeJs
nodejs项目windows下开机自启动的方法
Nov 22 NodeJs
nodejs(officegen)+vue(axios)在客户端导出word文档的方法
Jul 31 NodeJs
nodejs实现一个word文档解析器思路详解
Aug 14 NodeJs
Nodejs Express 通过log4js写日志到Logstash(ELK)
Aug 30 NodeJs
nodejs中方法和模块用法示例
Dec 24 NodeJs
详解如何在NodeJS项目中优雅的使用ES6
Apr 22 #NodeJs
nodejs和C语言插入mysql数据库乱码问题的解决方法
Apr 14 #NodeJs
解析NodeJS异步I/O的实现
Apr 13 #NodeJs
详解nodejs微信公众号开发——6.自定义菜单
Apr 13 #NodeJs
nodejs个人博客开发第七步 后台登陆
Apr 12 #NodeJs
nodejs个人博客开发第六步 数据分页
Apr 12 #NodeJs
nodejs个人博客开发第五步 分配数据
Apr 12 #NodeJs
You might like
请php正则走开
2008/03/15 PHP
php实现的在线人员函数库
2008/04/09 PHP
PHP的PDO预处理语句与存储过程
2019/01/27 PHP
laradock环境docker-compose操作详解
2019/07/29 PHP
js 解决“options为空或不是对象”
2008/12/22 Javascript
Tips 带三角可关闭的文字提示
2010/10/06 Javascript
jquery实现图片裁剪思路及实现
2013/08/16 Javascript
JavaScript中使用document.write向页面输出内容实例
2014/10/16 Javascript
js鼠标滑过图片震动特效的方法
2015/02/17 Javascript
jQuery简单实现日历的方法
2015/05/04 Javascript
Knockout自定义绑定创建方法
2015/12/26 Javascript
JCrop+ajaxUpload 图像切割上传的实例代码
2016/07/20 Javascript
vue组件学习教程
2017/09/09 Javascript
vue 开发一个按钮组件的示例代码
2018/03/27 Javascript
微信小程序出现wx.getLocation再次授权问题的解决方法分析
2019/01/16 Javascript
Vue结合后台导入导出Excel问题详解
2019/02/19 Javascript
[01:45]DOTA2众星出演!DSPL刀塔次级职业联赛宣传片
2014/11/21 DOTA
Python爬虫实例_城市公交网络站点数据的爬取方法
2018/01/10 Python
Python判断字符串是否为字母或者数字(浮点数)的多种方法
2018/08/03 Python
Python面向对象程序设计之继承、多态原理与用法详解
2020/03/23 Python
VSCode基础使用与VSCode调试python程序入门的图文教程
2020/03/30 Python
Python QTimer实现多线程及QSS应用过程解析
2020/07/11 Python
Hotels.com南非:酒店预订
2017/11/02 全球购物
俄罗斯游戏商店:Buka
2020/03/01 全球购物
生物专业个人自荐信范文
2013/11/29 职场文书
高一新生军训感言
2014/03/02 职场文书
公司2014年度工作总结
2014/12/10 职场文书
中国世界遗产导游词
2015/02/13 职场文书
年度考核个人总结
2015/03/06 职场文书
民间借贷纠纷答辩状
2015/08/03 职场文书
宾馆卫生管理制度
2015/08/06 职场文书
2019年特色火锅店的创业计划书模板
2019/08/28 职场文书
利用ajax+php实现商品价格计算
2021/03/31 PHP
python如何获取网络数据
2021/04/11 Python
用Python编写简单的gRPC服务的详细过程
2021/07/04 Python
项目中Nginx多级代理是如何获取客户端的真实IP地址
2022/05/30 Servers