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实用示例 缩址还原
Dec 28 NodeJs
Nodejs实现多人同时在线移动鼠标的小游戏分享
Dec 06 NodeJs
nodejs模块nodemailer基本使用-邮件发送示例(支持附件)
Mar 28 NodeJs
深入理解Nodejs Global 模块
Jun 03 NodeJs
nodejs接入阿里大鱼短信验证码的方法
Jul 10 NodeJs
Nodejs对postgresql基本操作的封装方法
Feb 20 NodeJs
Nodejs实现用户注册功能
Apr 14 NodeJs
M2实现Nodejs项目自动部署的方法步骤
May 05 NodeJs
如何让Nodejs支持H5 History模式(connect-history-api-fallback源码分析)
May 30 NodeJs
NodeJS实现一个聊天室功能
Nov 25 NodeJs
Nodejs + Websocket 指定发送及群聊的实现
Jan 09 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
关于手调机和数调机的选择
2021/03/02 无线电
基于thinkPHP3.2实现微信接入及查询token值的方法
2017/04/18 PHP
学习YUI.Ext 第三天
2007/03/10 Javascript
JavaScript CSS修改学习第六章 拖拽
2010/02/19 Javascript
点击隐藏页面左栏或右栏实现js代码
2013/04/01 Javascript
javascript使用定时函数实现跳转到某个页面
2013/12/25 Javascript
详解JavaScript语法对{}处理的坑爹之处
2014/06/05 Javascript
[原创]javascript typeof id==='string'?document.getElementById(id):id解释
2016/11/02 Javascript
JavaScript使用readAsDataURL读取图像文件
2017/05/10 Javascript
JS数组操作中的经典算法实例讲解
2017/07/26 Javascript
angular中的cookie读写方法
2017/08/02 Javascript
vue2.0移除或更改的一些东西(移除index key)
2017/08/28 Javascript
cropper js基于vue的图片裁剪上传功能的实现代码
2018/03/01 Javascript
vue cli2.0单页面title修改方法
2018/06/07 Javascript
浅谈webpack性能榨汁机(打包速度优化)
2019/01/09 Javascript
JS算法题之查找数字在数组中的索引位置
2019/05/15 Javascript
vue中使用 pako.js 解密 gzip加密字符串的方法
2019/06/10 Javascript
layui lay-verify form表单自定义验证规则详解
2019/09/18 Javascript
Vue学习之常用指令实例详解
2020/01/06 Javascript
Vue快速实现通用表单验证的示例代码
2020/01/09 Javascript
vuejs实现下拉框菜单选择
2020/10/23 Javascript
[44:51]2018DOTA2亚洲邀请赛 4.4 淘汰赛 VP vs Liquid 第二场
2018/04/05 DOTA
两个使用Python脚本操作文件的小示例分享
2015/08/27 Python
Python标准库shutil用法实例详解
2018/08/13 Python
Python使用googletrans报错的解决方法
2018/09/25 Python
pandas 数据索引与选取的实现方法
2019/06/21 Python
Java面试题:Java类的Main方法如果是Private将会怎么样
2016/08/18 面试题
市场拓展计划书
2014/05/03 职场文书
旅游饭店管理专业自荐书
2014/06/28 职场文书
员工安全责任书范本
2014/07/24 职场文书
2014年人民调解工作总结
2014/12/08 职场文书
教导主任个人总结
2015/03/03 职场文书
2015年青年志愿者协会工作总结
2015/04/27 职场文书
十大经典日本动漫排行榜 海贼王第三,犬夜叉仅第八
2022/03/18 日漫
MySQL学习之基础命令实操总结
2022/03/19 MySQL
VUE使用draggable实现组件拖拽
2022/04/06 Vue.js