如果想自己做一个脚手架或者在某些时候在 CMD 窗口进行交互,这个时候就可以使用 inquirer.js。
首先npm init 初始化一个文件夹,来测试这个库,然后安装包:
            
            
              js
              
              
            
          
          npm install --save inquirer
        再在文件夹里面新建一个 app.js,接下来的所有测试均在这个文件里面。
简单功能参数介绍
- type:表示提问的类型,包括:input、confirm、 list、rawlist、expand、checkbox、password、editor。
 - name: 存储当前输入的值。
 - message:问题的描述。
 - default:默认值。
 - choices:列表选项,在某些type下可用,并且包含一个分隔符(separator);
 - validate:对用户的回答进行校验。
 - filter:对用户的回答进行过滤处理,返回处理后的值。
 - when:根据前面问题的回答,判断当前问题是否需要被回答。
 - pageSize:修改某些type类型下的渲染行数。
 - prefix:修改message默认前缀。
 - suffix:修改message默认后缀。
 
input输入
一个输入
            
            
              js
              
              
            
          
          const inquirer = require("inquirer");
inquirer.prompt([
    {
        type:"input",
        message:"请输入你的姓名:",
        name:"name",
        default:"大傻子"
    }
]).then(answer=>{
    // 用户输入的结果最终会在这里输出
    console.log(answer);
});
        运行测试结果:
            
            
              js
              
              
            
          
          C:\Users\Administrator\Desktop\propt>node app.js
? 请输入你的姓名: Condoe Hero
{ name: 'Condoe Hero' }
C:\Users\Administrator\Desktop\propt>
        两个输入
            
            
              js
              
              
            
          
          const inquirer = require("inquirer");
inquirer.prompt([
    {
        type:"input",
        message:"请输入你的姓名:",
        name:"name",
        default:"大傻子"
    },
    {
        type:"input",
        message:"请输入你的年龄:",
        name:"age",
        default:18
    }
]).then(answer=>{
    // 用户输入的结果最终会在这里输出
    console.log(answer);
});
        程序运行结果:
            
            
              js
              
              
            
          
          C:\Users\Administrator\Desktop\propt>node app.js
? 请输入你的姓名: Condor Hero
? 请输入你的年龄: 18
{ name: 'Condor Hero', age: 18 }
C:\Users\Administrator\Desktop\propt>
        validate验证
            
            
              js
              
              
            
          
          const inquirer = require("inquirer");
inquirer.prompt([
    {
        type:"input",
        message:"请输入你的姓名:",
        name:"name",
        default:"大傻子"
    },
    {
        type:"input",
        message:"请输入你的年龄:",
        name:"age",
        default:18,
        validate:(val)=>{
            if(val > 10 && val < 120){
                return val;
            }else{
                return "我猜你绝对不是一个正常人类";
            }
        }
    }
]).then(answer=>{
    console.log(answer);
});
        测试结果:
            
            
              js
              
              
            
          
          C:\Users\Administrator\Desktop\propt>node app.js
? 请输入你的姓名: 大傻子
? 请输入你的年龄: (18) 18
>> 18
        confirm确认
            
            
              js
              
              
            
          
          const inquirer = require("inquirer");
inquirer.prompt([
    {
        type:"confirm",
        message:"是否现在监听?",
        name:"watch",
        default:true
    },
    {
        type: "confirm",
        message: "是否能看到我取决于上面是否通过?",
        name: "pass",
        suffix: "后缀",
        when: function(answer) { // 当watch为true的时候才会到达这步
            return answer.watch//只有我return true才会这个confirm
        }
    }
]).then(answer=>{
    console.log(answer);
});
        看看三种不同输入结果有啥变化?

前缀和后缀
            
            
              js
              
              
            
          
          const inquirer = require("inquirer");
inquirer.prompt([
    {
        type:"confirm",
        message:"是否现在监听?",
        name:"watch",
        default:true,
        prefix:"☆☆☆☆"//前缀
    },
    {
        type: "confirm",
        message: "是否能看到我取决于上面是否通过?",
        name: "pass",
        suffix: "****",//后缀
        when: function(answer) { // 当watch为true的时候才会到达这步
            return answer.watch //只有我return true才会这个confirm
        }
    }
]).then(answer=>{
    console.log(answer);
});
        
list 选项组
使用箭头选择
list 一般配合 choices 使用:
            
            
              js
              
              
            
          
          const inquirer = require("inquirer");
inquirer.prompt([
    {
        type:"list",
        message:"请选择一个选项:",
        name:"fruit",
        default:"Apple",
        prefix:"☆☆☆☆",
        suffix:"****",
        choices:[
            "Apple",
            "pear",
            "Banana"
        ],
        filter: function (val) { // 使用filter将值变为大写
            return val.toUpperCase();
        }
    }
]).then(answer=>{
    console.log(answer);
});
        查看动图效果:

使用数字选择
list 改成 rawlist
            
            
              js
              
              
            
          
          const inquirer = require("inquirer");
inquirer.prompt([
    {
        type:"rawlist",
        message:"请选择一个选项:",
        name:"fruit",
        default:"Apple",
        prefix:"☆☆☆☆",
        suffix:"****",
        choices:[
            "Apple",
            "pear",
            "Banana"
        ],
        filter: function (val) { // 使用filter将值变为大写
            return val.toUpperCase();
        }
    }
]).then(answer=>{
    console.log(answer);
});
        
使用简写(自动扩展成全写)
            
            
              js
              
              
            
          
          const inquirer = require("inquirer");
inquirer.prompt([
    {
        type:"expand",
        message:"请选择一个颜色:",
        name:"color",
        default:"red",
        choices:[
            {
                key : 'R',
                value : "red"
            },
            {
                key : 'B',
                value : "blue"
            },
            {
                key : 'G',
                value : "green"
            }
        ]
    }
]).then(answer=>{
    console.log(answer);
});
        
自己可以试试按下 h/H 回车的页面是啥。
多选和分隔符
            
            
              js
              
              
            
          
          const inquirer = require("inquirer");
inquirer.prompt([
    {
        type:"checkbox",
        message:"选择一至多种颜色:",
        name:"color",
        choices:[
            {
                name : "red"
            },
            new inquirer.Separator(), // 添加分隔符
            {
                name : "blue"
            },
            {
                name : "green"
            },
            {
                name : "pink",
                checked : true//默认
            },
            new inquirer.Separator("--- 分隔符 ---"), // 自定义分隔符
            {
                name : "orange"
            }
        ]
    }
]).then(answer=>{
    console.log(answer);
});
        
如果不想自定义还可以:
            
            
              js
              
              
            
          
          const inquirer = require("inquirer");
inquirer.prompt([
    {
        type:"checkbox",
        message:"选择一至多种颜色:",
        name:"color",
        choices:[
            "red",
            "blue",
            "green",
            "pink",
            "orange"
        ]
    }
]).then(answer=>{
    console.log(answer);
});
        
密码
            
            
              js
              
              
            
          
          const inquirer = require("inquirer");
inquirer.prompt([
    {
        type:"password",
        message:"请输入你的密码:",
        name:"pwd"
    }
]).then(answer=>{
    console.log(answer);
});
        
输入数字
            
            
              js
              
              
            
          
          const inquirer = require("inquirer");
inquirer.prompt([
    {
        type:"number",
        message:"请输入数字:",
        name:"num"
    }
]).then(answer=>{
    console.log(answer);
});
        
编辑器
使用首选编辑器打开一个临时文件,用户退出编辑器后,将读取临时文件的内容。首选编辑器可以指定。
            
            
              js
              
              
            
          
          const inquirer = require("inquirer");
inquirer.prompt([
    {
        type:"editor",
        message:"写下你想写的东西:",
        name:"editor"
    }
]).then(answer=>{
    console.log(answer);
});
        
行数
用来更改显示行数只对list, rawList, expand 或 checkbox有效。
            
            
              js
              
              
            
          
          const inquirer = require("inquirer");
inquirer.prompt([
    {
        type:"checkbox",
        message:"选择一至多种颜色:",
        name:"color",
        choices:[
            "red",
            "blue",
            "green",
            "pink",
            "orange"
        ],
        pageSize:1
    }
]).then(answer=>{
    console.log(answer);
});
        只有一行,通过上下方向键来选择:
