如何從Node.js中的命令行讀取輸入

本文翻譯自How to read input from the command line in Node.js

readline內(nèi)置模塊

您是否正在使用Node.js中開發(fā)一個(gè)小的CLI工具芬萍,并希望能夠提示用戶從命令行輸入輸入凤藏? Node.js正是為此目的提供了readline模塊项秉。 它提供了一個(gè)接口颠焦,用于從可讀流(例如process.stdin)中一次讀取一行數(shù)據(jù)鲜侥。

這是一個(gè)簡單的示例位仁,提示用戶輸入其姓名和國籍揣钦,然后在控制臺(tái)上打印這些詳細(xì)信息:

const readline = require('readline');

const rl = readline.createInterface({
    input: process.stdin,
    output: process.stdout
});

// ask user for the anme input
rl.question(`What's your name? `, (name) => {

    // ask for nationality
    rl.question(`What are you from? `, (country) => {

        // log user details
        console.log(`${name} is from ${country}`);

        // close the stream
        rl.close();
    });

});

在上面的示例中祭芦,readline.createInterface()方法用于通過定義可讀和可寫流來創(chuàng)建readline的實(shí)例移层。

rl.question()方法顯示查詢(問題)仍翰,并等待用戶輸入答案。 輸入數(shù)據(jù)可用后观话,它將調(diào)用回調(diào)方法予借,并將用戶輸入作為第一個(gè)參數(shù)。

最后频蛔,我們在最終的回調(diào)中調(diào)用rl.close()方法以關(guān)閉readline接口灵迫。 您還可以偵聽在關(guān)閉流時(shí)調(diào)用的close事件。 進(jìn)行一些后期提問可能會(huì)很有用:

// listen for close event
rl.on('close', () => {
    console.log("Goodbye ??");

    // exit the process
    process.exit(0);
    
});

查看readline文檔以了解有關(guān)所有可用方法和事件的更多信息晦溪。

第三方模塊-prompt

readline模塊是一個(gè)低級Node.js軟件包瀑粥,對于復(fù)雜的用例,您可能會(huì)認(rèn)為它太復(fù)雜了三圆。 如果要使用更高級別的界面來處理用戶輸入狞换,只需使用Node Package Manager(NPM)中的prompt模塊避咆。 您可以通過執(zhí)行以下命令將其添加到您的項(xiàng)目中:

$ npm install prompt --save

如果使用yarn作為包管理工具,可以執(zhí)行如下命令添加prompt模塊:

$ yarn add prompt --dev

readline模塊相比哀澈,使用prompt` 相對容易牌借。 您無需顯式配置可讀和可寫流。

讓我們使用提示模塊重寫以上示例:

const prompt = require('prompt');

// start the prompt
prompt.start();

// ask user for the input
prompt.get(['name', 'country'], (err, result) => {
    if (err) {
        throw err;
    }

    // print user details
    console.log(`${result.name} is from ${result.country}`);

});

處理密碼

提示模塊可以更輕松地安全地要求用戶輸入密碼割按。 它將屏蔽輸入膨报,而不顯示密碼的實(shí)際字符:

const prompt = require('prompt');

// start the prompt
prompt.start();

// define properties schema
var schema = {
    properties: {
        name: {
            pattern: /^[a-zA-Z\s\-]+$/,
            message: 'Name must be only letters, spaces, or dashes',
            required: true
        },
        password: {
            hidden: true
        }
    }
};


// ask user for the input
prompt.get(schema, (err, result) => {
    if (err) {
        throw err;
    }

    // print user credentials
    console.log(`${result.name} / ${result.password}`);

});

注意上例中的pattern屬性。 它確保在移至下一個(gè)屬性輸入之前适荣,正確驗(yàn)證了我們從用戶那里收到的name`屬性輸入现柠。

向?qū)ο筇砑訉傩?/h3>

提示模塊提供了另一個(gè)名為addProperties()的便捷方法,可通過從命令行添加屬性數(shù)據(jù)來擴(kuò)展現(xiàn)有對象:

const prompt = require('prompt');

// start the prompt
prompt.start();

// create an object
const user = {
    name: 'John Doe',
    country: 'USA'
};

// extend `user` object
prompt.addProperties(user, ['email', 'age'], (err) => {
    if (err) {
        throw err;
    }

    // print modified object
    console.dir(user);

});

現(xiàn)在弛矛,如果您運(yùn)行上述程序够吩,您應(yīng)該會(huì)看到類似于以下內(nèi)容的輸出:

$ node index.js
prompt: email:  john.doe@example.com
prompt: age:  23
{ name: 'John Doe',
  country: 'USA',
  email: 'john.doe@example.com',
  age: '23' }

如上所示,prompt是高度可定制的丈氓。 請查閱官方文檔以獲取更多信息周循。 如果您打算在Node.js中構(gòu)建可靠的CLI工具,則prompt可能是一個(gè)很好的選擇万俗。

喜歡這篇文章嗎湾笛? 在TwitterLinkedIn上關(guān)注我。 您也可以訂閱RSS Feed闰歪。

其他資料

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末嚎研,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子库倘,更是在濱河造成了極大的恐慌临扮,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,884評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件教翩,死亡現(xiàn)場離奇詭異杆勇,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)饱亿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,347評論 3 385
  • 文/潘曉璐 我一進(jìn)店門蚜退,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人路捧,你說我怎么就攤上這事关霸。” “怎么了杰扫?”我有些...
    開封第一講書人閱讀 157,435評論 0 348
  • 文/不壞的土叔 我叫張陵队寇,是天一觀的道長。 經(jīng)常有香客問我章姓,道長佳遣,這世上最難降的妖魔是什么识埋? 我笑而不...
    開封第一講書人閱讀 56,509評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮零渐,結(jié)果婚禮上窒舟,老公的妹妹穿的比我還像新娘。我一直安慰自己诵盼,他們只是感情好惠豺,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,611評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著风宁,像睡著了一般洁墙。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上戒财,一...
    開封第一講書人閱讀 49,837評論 1 290
  • 那天热监,我揣著相機(jī)與錄音,去河邊找鬼饮寞。 笑死孝扛,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的幽崩。 我是一名探鬼主播苦始,決...
    沈念sama閱讀 38,987評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼歉铝!你這毒婦竟也來了盈简?” 一聲冷哼從身側(cè)響起凑耻,我...
    開封第一講書人閱讀 37,730評論 0 267
  • 序言:老撾萬榮一對情侶失蹤太示,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后香浩,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體类缤,經(jīng)...
    沈念sama閱讀 44,194評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,525評論 2 327
  • 正文 我和宋清朗相戀三年邻吭,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了餐弱。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,664評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡囱晴,死狀恐怖膏蚓,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情畸写,我是刑警寧澤驮瞧,帶...
    沈念sama閱讀 34,334評論 4 330
  • 正文 年R本政府宣布,位于F島的核電站枯芬,受9級特大地震影響论笔,放射性物質(zhì)發(fā)生泄漏采郎。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,944評論 3 313
  • 文/蒙蒙 一狂魔、第九天 我趴在偏房一處隱蔽的房頂上張望蒜埋。 院中可真熱鬧,春花似錦最楷、人聲如沸整份。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,764評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽皂林。三九已至,卻和暖如春蚯撩,著一層夾襖步出監(jiān)牢的瞬間础倍,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,997評論 1 266
  • 我被黑心中介騙來泰國打工胎挎, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留沟启,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,389評論 2 360
  • 正文 我出身青樓犹菇,卻偏偏與公主長得像德迹,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子揭芍,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,554評論 2 349