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 】
相关推荐:
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法
微信小程序 HTTPS报错整理常见问题及解决方案
Win11怎么设置默认图片查看器_Windows11照片应用关联设置
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
Win11怎么关闭专注助手 Win11关闭免打扰模式设置【操作】
Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
Laravel如何使用模型观察者?(Observer代码示例)
Laravel怎么导出Excel文件_Laravel Excel插件使用教程
Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境
Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】
Laravel怎么实现一对多关联查询_Laravel Eloquent模型关系定义与预加载【实战】
Laravel安装步骤详细教程_Laravel环境搭建指南
深圳网站制作的公司有哪些,dido官方网站?
Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出
Laravel如何使用.env文件管理环境变量?(最佳实践)
如何用wdcp快速搭建高效网站?
Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析
JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)
郑州企业网站制作公司,郑州招聘网站有哪些?
WordPress 子目录安装中正确处理脚本路径的完整指南
Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康
Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧
Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程
Laravel如何升级到最新的版本_Laravel版本升级流程与兼容性处理
MySQL查询结果复制到新表的方法(更新、插入)
高端企业智能建站程序:SEO优化与响应式模板定制开发
Python图片处理进阶教程_Pillow滤镜与图像增强
Laravel如何实现模型的全局作用域?(Global Scope示例)
HTML透明颜色代码在Angular里怎么设置_Angular透明颜色使用指南【详解】
Laravel怎么调用外部API_Laravel Http Client客户端使用
Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例
Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门
Laravel如何实现用户角色和权限系统_Laravel角色权限管理机制
QQ浏览器网页版登录入口 个人中心在线进入
php嵌入式断网后怎么恢复_php检测网络重连并恢复硬件控制【操作】
如何在七牛云存储上搭建网站并设置自定义域名?
android nfc常用标签读取总结
Laravel如何使用Service Provider服务提供者_Laravel依赖注入与容器绑定【深度】
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
长沙企业网站制作哪家好,长沙水业集团官方网站?
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
专业商城网站制作公司有哪些,pi商城官网是哪个?
如何在香港服务器上快速搭建免备案网站?
php静态变量怎么调试_php静态变量作用域调试技巧【解答】
制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置

