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代码示例)
如何用狗爹虚拟主机快速搭建网站?

