代码拉取完成,页面将自动刷新
// 这里用到一个很实用的 npm 模块,用以在同一行打印文本
const slog = require("single-line-log").stdout;
// 封装的 ProgressBar 工具
function ProgressBar(description, bar_length) {
// 两个基本参数(属性)
this.description = description || "Progress"; // 命令行开头的文字信息
this.length = bar_length || 25; // 进度条的长度(单位:字符),默认设为 25
this.start = 0;
// 刷新进度条图案、文字的方法
this.render = function (opts) {
if (!this.start) this.start = Date.now();
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 +
" " +
"已运行:" +
formatTime(Date.now() - this.start);
// 在单行输出文本
slog(cmdText);
};
}
function formatTime(ms) {
let str = "";
let time = ms / 1000;
if (time < 1) return "0秒";
time = Math.floor(time);
str += (time % 60) + "秒";
time = Math.floor(time / 60);
if (time < 1) return str;
str = (time % 60) + "分" + str;
time = Math.floor(time / 60);
if (time < 1) return str;
str = (time % 60) + "小时" + str;
return str;
}
// 模块导出
module.exports = ProgressBar;
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。