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

发布时间 - 2026-01-11 00:46:52    点击率:

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使用七牛云存储上传文件的方法  # nodejs 实现模拟form表单上传文件  # Node.js成为Web应用开发最佳选择的原因  # 命令行  # 当我们  # 上传  # 设为  # 可用性  # 有多少  # 给大家  # 我将  # 只是一个  # 可以根据  # 在等待  # 比较容易  # 先说  # 大家多多  # 基本原理  # 多少个  # 过程中  # 不包含  # 长度为 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel怎么实现验证码(Captcha)功能  大同网页,大同瑞慈医院官网?  如何快速搭建个人网站并优化SEO?  Laravel如何使用Vite进行前端资源打包?(配置示例)  Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】  如何在阿里云香港服务器快速搭建网站?  如何快速搭建高效香港服务器网站?  深圳网站制作的公司有哪些,dido官方网站?  Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载  MySQL查询结果复制到新表的方法(更新、插入)  如何破解联通资金短缺导致的基站建设难题?  长沙做网站要多少钱,长沙国安网络怎么样?  怎么用AI帮你为初创公司进行市场定位分析?  html5源代码发行怎么设置权限_访问权限控制方法与实践【指南】  网站图片在线制作软件,怎么在图片上做链接?  Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区  Laravel如何创建和注册中间件_Laravel中间件编写与应用流程  Laravel如何配置任务调度?(Cron Job示例)  如何用AWS免费套餐快速搭建高效网站?  如何在Windows 2008云服务器安全搭建网站?  如何基于云服务器快速搭建网站及云盘系统?  Laravel如何使用模型观察者?(Observer代码示例)  Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南  高防服务器租用指南:配置选择与快速部署攻略  微信推文制作网站有哪些,怎么做微信推文,急?  Laravel如何使用查询构建器?(Query Builder高级用法)  js实现获取鼠标当前的位置  jQuery validate插件功能与用法详解  英语简历制作免费网站推荐,如何将简历翻译成英文?  如何在腾讯云免费申请建站?  Laravel如何处理和验证JSON类型的数据库字段  Laravel如何从数据库删除数据_Laravel destroy和delete方法区别  html5怎么画眼睛_HT5用Canvas或SVG画眼球瞳孔加JS控制动态【绘制】  javascript日期怎么处理_如何格式化输出  Laravel项目怎么部署到Linux_Laravel Nginx配置详解  Android GridView 滑动条设置一直显示状态(推荐)  html5audio标签播放结束怎么触发事件_onended回调方法【教程】  Laravel怎么为数据库表字段添加索引以优化查询  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  使用PHP下载CSS文件中的所有图片【几行代码即可实现】  如何生成腾讯云建站专用兑换码?  详解vue.js组件化开发实践  Android Socket接口实现即时通讯实例代码  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南  如何快速搭建高效简练网站?  微信小程序 require机制详解及实例代码  百度输入法ai组件怎么删除 百度输入法ai组件移除工具  Laravel如何配置和使用缓存?(Redis代码示例)  如何用狗爹虚拟主机快速搭建网站?