资讯专栏INFORMATION COLUMN

nodejs 终端打印进度条

dack / 3649人阅读

摘要:那么使用简单的文本和符号,就够自己拼凑出命令行的效果下面例子文件已上传当然,进度条的效果可以根据需要自己设计啦,我这里只是给大家一个参考。

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
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 一下上面的代码,执行效果如下:

原创文章,转载请注明出处

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/82618.html

相关文章

  • Nodejs命令行光标位置的设置

    摘要:引子很多使用开发的工具都会提供一个命令行操作界面,这些工具在执行的过程中会实时更新执行进度或数据的下载解压缩进度等,例如,这些信息会再终端的同一行的同一位置显示,而不是一行一行逐次打印显示那么其是怎么实现的有没有相应地模块提供这个功能呢嗯, 引子 很多使用nodejs开发的工具都会提供一个命令行操作界面(CLI),这些工具在执行的过程中会实时更新执行进度或数据的下载解压缩进度等,例如1...

    Null 评论0 收藏0
  • nodejs 初入--learnyounode课程总结(上)

    摘要:编写一个简单的程序,使其能接收一个或者多个命令行参数,并且在终端标准输出中打印出这些参数的总和。处理所有可能发生的错误,并把它们传递给回调函数。编写一个程序来发起一个请求,所请求的为命令行参数的第一个。 learnyounode 13课总结(上) 最近对nodejs比较感兴趣,但是苦于无法下手,直接啃文档又觉得十分生硬无趣。 幸好有热心网友推荐了learnyounode这个好玩的入...

    masturbator 评论0 收藏0
  • 一步一步搭建一个图片上传网站(后台服务器用nodejs

    摘要:把文件上传路径指定到然后用当前日期和文件名命名上传过来的文件。后端利用建立服务器,利用中间件指定文件路径。利用这个前端和后端技术,我们基本上就可以做出一个图片上传存储的基本网站核心。 前几天看了腾讯云社区的一个文件上传的文章文件上传那些事儿,大体上讲了以下h5中图片上传的几个核心原理,但是没有后端接受的服务器代码,没法做测试。也没有具体的一个实例都是一些基本的原理片段,并且ui界面也不...

    Darkgel 评论0 收藏0
  • Python——基本数据类型(模块2: time库的使用)(实例3:文本进度

    摘要:前言本篇主要介绍基本数据类型,以文本进度条为例,介绍库的使用。 前言 本篇主要介绍基本数据类型,以文本进度条为例,介绍time库的使用。 并在最后对蟒蛇绘制的代码进...

    Jenny_Tong 评论0 收藏0
  • nodejs做了一个网易相册全量下载工具

    摘要:起因前几天网易相册宣布即将停止运营,自己有几千张照片需要下载,官方给的批量下载工具已经无法打开下载页面。无奈只能自己做一个。如果感动了你,可以在下面小额打赏,对我的支持和鼓励。 起因:前几天网易相册宣布即将停止运营,自己有几千张照片需要下载,官方给的批量下载工具已经无法打开下载页面。无奈只能自己做一个。 该教程专为小白用户写的,大神请直接移步github:https://github....

    elva 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<