zoukankan      html  css  js  c++  java
  • 使用nodejs从控制台读入内容

    在写算法题的时候,基本上都需要输入输出语句,在大多数练题网站上当想用js书写算法题时,发现不知道怎么输入,其实Node是提供了一个readline模块来实现此功能的

    tip
    笔者用过的练题网站只有leetcode在使用js书写时只需要实现功能函数就行,就不需要考虑如何从键盘录入内容

    简单使用

    const readline = require('readline')
    
    const rl = readline.createInterface({
        input: process.stdin,
        output: process.stdout
    })
    // 监听键入回车事件
    rl.on('line', (str) => {
        // str即为输入的内容
        if (str === 'close') {
            // 关闭逐行读取流 会触发关闭事件
            rl.close()
        }
        console.log(str);
    })
    
    // 监听关闭事件
    rl.on('close', () => {
        console.log('触发了关闭事件');
    })
    

    假设上面的文件叫read.js,接下来我们直接输入下面运行

    node read.js
    

    上面的逻辑是输入字符串 close时退出程序

    感觉并没有其它语言用起来那么安逸,比如:

    • C++:cin>>param
    • C:scanf("%s",&param)
    • C#:param = Console.ReadLine()
    • ...等等

    怎样才能变得向上面那样用起来输入一点呢?我们为上面代码包装一下

    封装

    const readline = require('readline')
    
    const rl = readline.createInterface({
        input: process.stdin,
        output: process.stdout
    })
    
    /**
     * 读入一行
     */
    function readLine() {
        return new Promise(resolve => {
            rl.on('line', (str) => {
                resolve(str)
            })
        })
    }
    
    /**
     * 退出逐行读取
     */
    function close() {
        rl.close()
    }
    
    module.exports = {
        readLine,
        close
    }
    

    我们在编写一个新的test.js,上面的叫read.js 放在同一目录下

    const { readLine, close } = require('./read')
    
    /**
     * 运行的main函数
     **/
    async function main() {
        let i = await readLine();
        while (+i !== 0) {
            console.log(`你输入的是${i}`);
            i = await readLine();
        }
        close();
    }
    
    // 调用执行
    main();
    

    现在用起来就方便多了,只需要在函数结束时加上close不然不会退出

  • 相关阅读:
    Sql Server 2005 遍历结果集方法之一
    WinForm 程序托盘及右键退出
    WinForm 程序托盘
    JavaScript 简单定时器原理
    利用Httphandler实现URL重写(重写URL及伪静态)
    CYSCode 生成ORM框架的属性代码
    WinForm开机启动 判断 设置
    同级元素,鼠标经过高亮,鼠标离开还原(除选中已高亮元素时),点击确定高亮
    JavaScript 获取地址栏参数值
    openssl aes 加解密
  • 原文地址:https://www.cnblogs.com/roseAT/p/12348230.html
Copyright © 2011-2022 走看看