前端开发交互式命令之inquirer

inquirer 创建一个问答式的命令行交互,包括输入、列表选择、确认等。

  • npm 安装了 inquirer
cmd 复制代码
npm install inquirer
  • 例子
demo.js 复制代码
const inquirer = require('inquirer');

// 问题列表
const questions = [
  {
    type: 'input',     // 文本输入
    name: 'username',
    message: '请输入用户名:',
    validate: input => input.trim() ? true : '用户名不能为空'
  },
  {
    type: 'password',  // 密码输入
    name: 'password',
    message: '请输入密码:',
    mask: '*',         // 掩码显示
    validate: input => input.length >= 6 || '密码至少6位'
  },
  {
    type: 'list',      // 单选列表
    name: 'role',
    message: '选择您的角色:',
    choices: ['管理员', '编辑', '游客'],
    default: '游客'
  },
  {
    type: 'checkbox',  // 多选框
    name: 'skills',
    message: '选择您的技能:',
    choices: [
      { name: 'JavaScript', checked: true },
      { name: 'Python' },
      { name: 'Java' },
      { name: 'Go' }
    ]
  },
  {
    type: 'confirm',   // 确认框
    name: 'confirm',
    message: '是否接受协议?',
    default: false
  },
  {
    type: 'number',    // 数字输入
    name: 'age',
    message: '请输入年龄:',
    validate: input => (input >= 18 && input <= 100) || '年龄需在18-100之间'
  }
];

// 运行询问
inquirer.prompt(questions)
  .then(answers => {
    console.log('\n======= 收集结果 =======');
    console.log('用户名:', answers.username);
    console.log('密码:', '*'.repeat(answers.password.length));
    console.log('角色:', answers.role);
    console.log('技能:', answers.skills.join(', '));
    console.log('接受协议:', answers.confirm ? '是' : '否');
    console.log('年龄:', answers.age);
  })
  .catch(error => {
    console.error('发生错误:', error);
  });
  • 运行
cmd 复制代码
node demo.js
  • 运行效果
cmd 复制代码
? 请输入用户名: John
? 请输入密码: ******
? 选择您的角色: (Use arrow keys)
❯ 管理员 
  编辑 
  游客
? 选择您的技能: (Press <space> to select, <a> to toggle all, <i> to invert selection)
❯◯ JavaScript
 ◯ Python
 ◯ Java
 ◯ Go
? 是否接受协议? (y/N) 
? 请输入年龄: 25

这个示例覆盖了 inquirer 的常用功能,你可以根据需要调整问题类型、选项和验证逻辑。更多高级用法可参考官方文档

相关推荐
paopaokaka_luck31 分钟前
基于SpringBoot+Uniapp的健身饮食小程序(协同过滤算法、地图组件)
前端·javascript·vue.js·spring boot·后端·小程序·uni-app
患得患失9491 小时前
【前端】【vscode】【.vscode/settings.json】为单个项目配置自动格式化和开发环境
前端·vscode·json
飛_1 小时前
解决VSCode无法加载Json架构问题
java·服务器·前端
YGY Webgis糕手之路4 小时前
OpenLayers 综合案例-轨迹回放
前端·经验分享·笔记·vue·web
90后的晨仔4 小时前
🚨XSS 攻击全解:什么是跨站脚本攻击?前端如何防御?
前端·vue.js
Ares-Wang4 小时前
JavaScript》》JS》 Var、Let、Const 大总结
开发语言·前端·javascript
90后的晨仔4 小时前
Vue 模板语法完全指南:从插值表达式到动态指令,彻底搞懂 Vue 模板语言
前端·vue.js
德育处主任4 小时前
p5.js 正方形square的基础用法
前端·数据可视化·canvas
烛阴4 小时前
Mix - Bilinear Interpolation
前端·webgl
90后的晨仔5 小时前
Vue 3 应用实例详解:从 createApp 到 mount,你真正掌握了吗?
前端·vue.js