listr2 入门教程2-Node.js持续显示任务运行状态

上一篇介绍了 listr2 的安装和基本用法。本篇讲解一下,如何利用 listr2 任务的特性制作一个任务看板。

有时候我们需要在控制台持续显示某一个任务的执行状态,如监听一个串口,记录它收到了几次数据,这时我们可以使用 listr2 创建一个任务列表:

主要代码

index.ts:

ts 复制代码
import { Listr, PRESET_TIMER } from "listr2";
import { analyser } from "./analyser";
import { dynamometer } from "./dynamometer";
const lists = new Listr(
  [
    {
      title: "标定设备模拟",
      task: (ctx, task) =>
        task.newListr(
          [
            {
              title: "模拟分析仪",
              task: (ctx, task) =>
                new Promise(() => {
                  analyser(str => {
                    task.title = "模拟分析仪:" + str;
                  });
                }),
            },
            {
              title: "模拟测功机",
              task: (ctx, task) =>
                new Promise(() => {
                  dynamometer(str => {
                    task.title = "模拟测功机:" + str;
                  });
                }),
            },
          ],
          {
            concurrent: true,
            exitOnError: true,
            rendererOptions: { collapseSubtasks: false },
          }
        ),
    },
  ],
  {
    exitOnError: true,
    concurrent: false,
  }
);

lists.run().catch(err => {
  console.error(err);
});

分析以上代码,listr2 的任务接收一个返回 Promise 的函数,Promise 的状态控制 listr2 任务的完成状态,可以控制始终不执行 Promise 的 resolve 回调,这样任务就能一直保持运行状态。

同时,在执行任务过程中,可以修改task的标题,向用户传递信息,例如当前串口执行了多少次。

其余代码

其中 analyser 是模拟分析仪设备的,走 tcp 通信,包含接收数据和自动回复

dynamometer 是模拟测功机设备的,走串口通信,同样包含接收数据和自动回复

可以用以下代码模拟通信: analyser.ts

ts 复制代码
import net from "net";

/**
 * 模拟分析仪
 */
export function analyser(callback: (str: string) => void) {
  const server = net.createServer(socket => {
    callback("开始模拟");
    let count = 0;

    socket.on("data", data => {
      socket.write(`1,2,${3 + ++count}`);
      callback(`已收到数据,已自动回发数据 x${count}`);
    });

    socket.on("end", () => {
      callback("连接结束");
    });

    socket.on("close", () => {
      callback("连接关闭");
    });
    socket.addListener("error", err => {
      callback("连接出错");
    });
  });

  server.listen(9988, "127.0.0.1", () => {
    callback(`分析仪运行在 http://127.0.0.1:9988/`);
  });
}

dynamometer.ts

ts 复制代码
import { SerialPort } from "serialport";

// 模拟测功机
export function dynamometer(callback: (str: string) => void) {
  const serialPort = new SerialPort({
    path: "COM5",
    baudRate: 38400,
    stopBits: 1,
    parity: "none",
    dataBits: 8,
    autoOpen: true,
  },() => {
    callback(`模拟成功, 等待数据中`);
  });
  let count = 0;
  // 接收到就回发
  serialPort.on("data", data => {
    callback(`收到串口数据 [${Array.from(data).toString()}], 稍后自动回发 x${++count}`);

    setTimeout(() => {
      serialPort.write(data);
      callback(`回发串口数据 [${Array.from(data).toString()}] x${++count}`);
    }, 1000);
  });
}

效果演示

使用VSPD创建一对虚拟串口 COM5COM6

上面的dynamometer.ts 监听了COM5 ,我们使用串口助手,向COM6 发送数据,用以观察效果,由于是一对虚拟串口,COM6 收到数据会自动发送给COM5

效果如下:

相关推荐
Q_Q19632884751 小时前
python的电影院座位管理可视化数据分析系统
开发语言·spring boot·python·django·flask·node.js·php
一枚前端小能手4 小时前
⚡ Node.js服务器慢得像蜗牛,性能优化实战分享
前端·node.js·dnodejs
Cecilialana7 小时前
在安装 node-sass 时出现的编译问题
webpack·node.js
前端双越老师9 小时前
【干货】使用 langChian.js 实现掘金“智能总结” 考虑大文档和 token 限制
人工智能·langchain·node.js
一枚小小程序员哈19 小时前
基于Vue + Node能源采购系统的设计与实现/基于express的能源管理系统#node.js
vue.js·node.js·express
海上彼尚21 小时前
使用 npm-run-all2 简化你的 npm 脚本工作流
前端·npm·node.js
开发者小天21 小时前
为什么 /deep/ 现在不推荐使用?
前端·javascript·node.js
一枚小小程序员哈1 天前
基于Vue的个人博客网站的设计与实现/基于node.js的博客系统的设计与实现#express框架、vscode
vue.js·node.js·express
刘永胜是我1 天前
node版本切换
前端·node.js
我是哈哈hh1 天前
【Node.js】ECMAScript标准 以及 npm安装
开发语言·前端·javascript·node.js