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 相关文章推荐
Ubuntu中搭建Nodejs开发环境过程分享
Jun 01 NodeJs
nodejs npm包管理的配置方法及常用命令介绍
Jun 05 NodeJs
Highcharts+NodeJS搭建数据可视化平台示例
Jan 01 NodeJs
nodejs开发——express路由与中间件
Mar 24 NodeJs
Nodejs--post的公式详解
Apr 29 NodeJs
nodejs后台集成ueditor富文本编辑器的实例
Jul 11 NodeJs
深入学习nodejs中的async模块的使用方法
Jul 12 NodeJs
nodejs 最新版安装npm 的使用详解
Jan 18 NodeJs
Linux Centos7.2下安装nodejs&amp;npm配置全局路径的教程
May 15 NodeJs
nodejs实现套接字服务功能详解
Jun 21 NodeJs
详解nodejs解压版安装和配置(带有搭建前端项目脚手架)
Dec 06 NodeJs
基于nodejs的微信JS-SDK简单应用实现
May 21 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生成月历代码
2007/06/14 PHP
PHP 字符串编码截取函数(兼容utf-8和gb2312)
2009/05/02 PHP
php 无法载入mysql扩展
2010/03/12 PHP
php文件上传表单摘自drupal的代码
2011/02/15 PHP
浅析PHP文件下载原理
2014/12/25 PHP
php中使用gd库实现远程图片下载实例
2015/05/12 PHP
PHP中把有符号整型转换为无符号整型方法
2015/05/27 PHP
PHP设计模式之观察者模式实例
2016/02/22 PHP
PHP中实现中文字串截取无乱码的解决方法
2018/05/29 PHP
Yii 框架入口脚本示例分析
2020/05/19 PHP
javascript工具库代码
2012/03/29 Javascript
解决JS中乘法的浮点错误的方法
2014/01/03 Javascript
JavaScript的设计模式经典之代理模式
2016/02/24 Javascript
JS图片定时翻滚效果实现方法
2016/06/21 Javascript
原生js仿jquery实现对Ajax的封装
2016/10/04 Javascript
Vue+Express实现登录状态权限验证的示例代码
2019/05/05 Javascript
js实现全选和全不选功能
2020/07/28 Javascript
使用node-media-server搭建一个简易的流媒体服务器
2021/01/20 Javascript
python中使用正则表达式的连接符示例代码
2017/10/10 Python
python学生信息管理系统
2018/03/13 Python
pytorch 归一化与反归一化实例
2019/12/31 Python
简单了解Django ORM常用字段类型及参数配置
2020/01/07 Python
苹果中国官方网站:Apple中国
2016/07/22 全球购物
Emporio Armani腕表天猫官方旗舰店:乔治·阿玛尼为年轻人设计的副线品牌
2017/07/02 全球购物
美国高档百货Nordstrom的折扣店:Nordstrom Rack
2017/11/13 全球购物
英国屋顶用品和材料超市:Roofing Supplies UK
2019/08/24 全球购物
NET程序员上机面试题
2015/05/23 面试题
乔迁之喜主持词
2014/03/27 职场文书
机电一体化应届生求职信
2014/08/09 职场文书
学校周年庆活动方案
2014/08/22 职场文书
2014离婚协议书范文
2014/09/10 职场文书
基层组织建设年活动总结
2015/05/09 职场文书
优秀党员主要事迹材料
2015/11/04 职场文书
Django使用redis配置缓存的方法
2021/06/01 Redis
详解Spring Security中的HttpBasic登录验证模式
2022/03/17 Java/Android
tomcat正常启动但网页却无法访问的几种解决方法
2022/05/06 Servers