使用 propmts 创建你自己的交互式命令行表单

引言

REPL 是 R(read)、E(evaluate)、P(print)、L(loop) 的缩写,称为交互式命令行,是程序用来读取用户的输入的方式。比如在 C 语言中调用<stdio.h> 中的 scanf 函数收集用户输入的数据。在执行 npm init 时,也会出现 REPL 收集创建 npm 包时所需的信息。
再比如:我们在使用 @vue-cli 脚手架创建项目时,敲下vue create my-app命令后,会弹出配置选择交互菜单:

 Vue CLI v4.5.8
┌──────────────────────────────────────────┐
│                                          │
│   New version available 4.5.8 → 4.5.10   │
│     Run npm i -g @vue/cli to update!     │
│                                          │
└──────────────────────────────────────────┘

? Please pick a preset: (Use arrow keys)
  Default ([Vue 2] babel, eslint)
  Default (Vue 3 Preview) ([Vue 3] babel, eslint)
  Manually select features 
? Please pick a preset: Manually select features
? Check the features needed for your project: (Press <space> to select, <a> to toggle all, <i> to invert selection)
 (*) createChoice Vue version
 (*) Babel
 ( ) TypeScript
 ( ) Progressive Web App (PWA) Support
>( ) Router
 ( ) Vuex
 ( ) CSS Pre-processors
 (*) Linter / Formatter
 ( ) Unit Testing
 ( ) E2E Testing 

这种便捷友好的 REPL 拓展工具,外形美观、功能强大,而实现起来也非常简单。下面就开始介绍一款 node 的 repl 工具:prompts

Prompts 介绍和使用

Lightweight, beautiful and user-friendly interactive prompts
轻量、美观与易用的交互式命令提示工具

npm 安装,不必多言

npm install prompts

我们来实现一个简易表单,获取某射击游戏,玩家输入的用户名、密码、年龄等基本信息:

const prompts = require('prompts');


~async function () {
    const createChoice = (title, disable) => ({ title, value: title, disable: !!disable });

    const res = await prompts([
        {
            type: 'text', // 文字类型
            name: 'user',
            message: 'input user'
        },
        {
            type: 'password', // 密码类型
            name: 'password',
            message: 'input: password'
        },
        {
            type: 'number', // 数字类型
            name: 'age',
            message: 'input age'
        },
        {
            type: 'select', // 单选
            name: 'gender',
            message: 'your gender',
            choices: [createChoice('male'), createChoice('female'), createChoice('others')]
        },
        {
            type: 'multiselect', // 多选
            name: 'weapons',
            message: 'select your weapon',
            choices: [
                createChoice('M16A4'),
                createChoice('AK-74'),
                createChoice('QBZ-95'),
                createChoice('MP5'),
                createChoice('P90'),
                createChoice('Kar-98K'),
                createChoice('Dragunov'),
                createChoice('DesertEagle'),
                createChoice('Glock-18'),
            ]
        }
    ]);

    console.log(JSON.stringify(res));
}();

运行脚本,填单过程如下,与上文 vue 脚手架工具相差无几:

√ input user ... Soap
√ input: password ... ***
√ input age ... 33
√ your gender » male
? select your weapon »
Instructions:
    ↑/↓: Highlight option
    ←/→/[space]: Toggle selection
    a: Toggle all
    enter/return: Complete answer
(*)   M16A4
( )   AK-74
( )   QBZ-95
( )   MP5
( )   P90
( )   Kar-98K
( )   Dragunov
(*)   DesertEagle
(*)   Glock-18 

最后输出结果:

{"user":"Soap","password":"141","age":33,"gender":"male","weapons":["M16A4","DesertEagle","Glock-18"]}
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容