이 기사에서는 노드연습에 대해 단계별로 알아보고 노드 기반 mycli 명령줄 도구/스캐폴딩을 만드는 방법에 대해 설명합니다. 모든 사람에게 도움이 되기를 바랍니다.
먼저 컴퓨터에 node.js환경이 있는지 확인하세요
명령줄에서 다음 코드를 실행하여 package.json file<code>package.json
文件
npm init -y
此时,命令行执行mycli
肯定会报错。
配置自定义命令
package.json
添加bin
字段,关联mycli
命令
"bin": { "mycli": "./test.js" },
/test.js
文件console.log("mycli命令执行成功");
install
安装命令,但是项目还没有发布到npm,所以暂时先用npm link
命令,把mycli
命令关联到全局。此时命令行再执行 mycli
就不会再报错。
脚本配置
test.js文件:
console.log("mycli命令执行成功");
然后再执行 mycli
,此时会出现一个提示错误的弹窗
这是因为,执行mycli
命令的时候相当于让计算机执行了这个文件,而计算机系统是无法直接执行js文件的,这就需要我们在脚本代码第一行加入一个配置,指定计算机上的node.js
程序来执行这个js脚本文件。
#!/usr/bin/env node
由于更改了执行环境,需要删除之前link到的文件,文件位置可能是C:Program Filesnodejsnode_modules
,找到mycli
删除,然后再重新执行npm link
。
现在控制台再来执行mycli
,可以看到控制台正确打印。
Chalk
命令行输出五颜六色的字体Ora
加载中loading的效果,类似的还有progress库commander
设计命令inquirer
交互功能(如:提问...)Chalk
npm install chalk@4.1.2 -S
const chalk = require("chalk"); // chalk // const hello = chalk.red("hello"); // const hello = chalk.blue.bgRed("hello"); // const hello = chalk.blue.bgYellow("hello"); const hello = chalk.rgb(200, 200, 200).bgRgb(0, 200, 3)("hello"); console.log(hello);
Ora
npm install ora@4.0.3 -S
const ora = require("ora"); // ora const spinner = ora({ text: "安装中..." }); spinner.start(); setTimeout(() => { // spinner.stop(); spinner.succeed("安装成功"); // console.log("安装成功"); }, 2000)
start
开始加载stop
停止加载succeed
结束加载并带有成功的样式commander
开发中经常使用的命令,如vue -V
git --version
vue create
等命令,想要实现这样的命令需要用到commander这个库。
使用的命令后面带的-V
--help
等,可以理解为是命令的参数,那么我们就需要获取到这些参数,通过判断参数的不同来处理不同的事件。
那在node环境中,可以通过process.argv
来获取到这个参数。而commander库,帮助我们封装好了一些方法,不用我们自己去判断用户输入携带的指令是什么。
npm install commander@8.2.0 -S
const commander = require("commander"); // ... commander.parse(process.argv); // 放在后面
安装完成之后,commander会自动提供给我们一些命令,如--help
,下面来测试一下:
mycli --help
commander.version("1.0.0");
执行 mycli -V
可以看到控制台打印了 1.0.0
版本号。
自定义指令方法
commander.option(指令名, 描述, 回调函数)
--init
指令:commander.option("--init", "this is init", () => { // chalk // const hello = chalk.red("hello"); // const hello = chalk.blue.bgRed("hello"); // const hello = chalk.blue.bgYellow("hello"); const hello = chalk.rgb(200, 200, 200).bgRgb(0, 200, 3)("hello"); console.log(hello); // ora const spinner = ora({ text: "安装中..." }); spinner.start(); setTimeout(() => { // spinner.stop(); spinner.succeed("安装成功"); // console.log("安装成功"); }, 1000) })
现在执行mycli --init
commander.option("--number <num>", "log a number", (num) => { console.log(num); })
mycli
를 실행하면 반드시 오류가 보고됩니다. 🎜🎜 사용자 정의 명령 구성🎜🎜🎜package.json
bin
필드를 추가하고 mycli
Command🎜commander.command("create <projectName>").action((projectName)=>{ console.log(projectName); })
/test.js
만들기 file li>npm install inquirer -S
install
설치 명령이 필요하지만 프로젝트가 npm에 게시되지 않았으므로 당분간 다음을 사용하십시오. npm link
명령을 넣어 < code>mycli 명령은 전역 세계와 연결됩니다. mycli
를 실행하면 더 이상 오류가 보고되지 않습니다. 🎜🎜🎜🎜🎜 스크립트 구성🎜🎜🎜test.js 파일: 🎜inquirer.prompt([ { type: "input", name: "username", message: "请输入用户名:" } ]).then((answer)=>{ })
mycli
를 실행하면 오류 메시지가 나타납니다. 위로 창🎜🎜🎜 🎜이것은 mycli
명령을 실행할 때 컴퓨터가 파일을 실행하도록 하는 것과 동일하며 컴퓨터 시스템이 🎜js 파일을 직접 실행할 수 없으므로🎜 이를 추가해야 하기 때문입니다. 스크립트 코드의 첫 번째 줄 이 js 스크립트 파일을 실행하기 위해 컴퓨터의 node.js
프로그램을 지정하는 구성입니다. 🎜const inquirer = require("inquirer"); commander.command("add user").action(() => { inquirer.prompt([ { type: "input", name: "username", message: "请输入用户名:" } ]).then((answer) => { console.log(answer); }) })
C:Program Filesnodejsnode_modules
일 수 있으니, mycli
를 찾아 삭제하세요. 그런 다음 npm link
를 다시 실행하세요. 🎜🎜이제 콘솔에서 mycli
를 실행하면 콘솔이 올바르게 인쇄되는 것을 볼 수 있습니다. 🎜🎜🎜관련 툴킷 사용🎜🎜Chalk
명령줄 출력 다채로운 글꼴Ora
로딩 효과, 진행 상황과 유사 라이브러리 commander
디자인 명령 inquirer
대화형 기능(예: 질문하기...)< /li>< /ul>🎜🎜분필🎜🎜commander.command("testcon").action(() => { inquirer.prompt([ { type: "confirm", name: "age", message: "是否大于18岁?" } ]).then((answer) => { console.log(answer); }) })
commander.command("testlist").action(() => { inquirer.prompt([ { type: "list", name: "lib", message: "选择用到的框架:", choices: [ "vue2", "vue3", "react", "svelte", ] } ]).then((answer) => { console.log(answer); }) })
npm install download-git-repo@3.0.2 -S
const downgit = require("download-git-repo"); downgit("github:kongcodes/vue3-vant", downUrl, { clone: false }, function (err) { console.log(err) })
start
를 사용하여 로드 시작succeed
성공적인 스타일로 로드 종료vue -V
git --version
vue create</code와 같이 개발에 일반적으로 사용되는 명령 > 및 기타 명령을 구현하려면 🎜commander🎜 라이브러리를 사용해야 합니다. 🎜🎜명령 뒤에 나오는 <code>-V
--help
는 명령의 매개변수로 이해될 수 있습니다. 그런 다음 이러한 매개변수를 가져와서 다른 매개변수를 판단해야 합니다. 다양한 이벤트를 처리합니다. 🎜🎜🎜node🎜 환경에서는 process.argv
를 통해 이 매개변수를 얻을 수 있습니다. 🎜commander🎜 라이브러리는 사용자 입력에 따른 명령을 판단할 필요 없이 일부 메서드를 캡슐화하는 데 도움이 됩니다. 🎜commander.command("create <projectName>").action((projectName) => { const spinner = ora({ text: "正在下载https://github.com/kongcodes/vue3-vant..." }); spinner.start(); fs.mkdirSync(`./${projectName}`); const downUrl = `${process.cwd()}\${projectName}`; downgit("github:kongcodes/vue3-vant", downUrl, { clone: false }, function (err) { if (err) throw err; spinner.stop(); console.log(chalk.green("downgit success")); }) })
--help
, 아래에서 테스트해 보겠습니다. 🎜rrreeemycli 실행 -V</ code>콘솔에 <code>1.0.0
버전 번호가 인쇄되는 것을 볼 수 있습니다. 🎜🎜🎜사용자 정의 명령 방법🎜🎜🎜commander.option(명령 이름, 설명, 콜백 함수)
🎜-- init<로 구성합니다. /code> 명령: </li></ul>rrreee🎜이제 <code>mycli --init
테스트를 실행합니다: 🎜🎜🎜🎜commander.option("--number <num>", "log a number", (num) => { console.log(num); })
<参数名>
表示必传的参数,[参数名]
表示非必传的参数。控制台输入mycli --number 100
回车,可以看到会输出100
。
自定义命令方法
commander.command("create <projectName>").action((projectName)=>{ console.log(projectName); })
执行 mycli create xx
回车,控制台可以看到 输出了xx
。
查看帮助
执行 mycli --help
,可以看到我们刚才配置的指令和命令都出现在了帮助列表里。
inquirer
npm install inquirer -S
prompt
提问的方法inquirer.prompt([ { type: "input", name: "username", message: "请输入用户名:" } ]).then((answer)=>{ })
type
表示问题的类型,取值可能是:input
, number
, password
, editor
等。
answer
是 {username: 输入的值}
input
const inquirer = require("inquirer"); commander.command("add user").action(() => { inquirer.prompt([ { type: "input", name: "username", message: "请输入用户名:" } ]).then((answer) => { console.log(answer); }) })
confirm
commander.command("testcon").action(() => { inquirer.prompt([ { type: "confirm", name: "age", message: "是否大于18岁?" } ]).then((answer) => { console.log(answer); }) })
输入y
或n
来进行判断。
list
commander.command("testlist").action(() => { inquirer.prompt([ { type: "list", name: "lib", message: "选择用到的框架:", choices: [ "vue2", "vue3", "react", "svelte", ] } ]).then((answer) => { console.log(answer); }) })
执行 mycli testlist
命令:
download-git-repo是一个拉取代码的工具。
安装
npm install download-git-repo@3.0.2 -S
const downgit = require("download-git-repo"); downgit("github:kongcodes/vue3-vant", downUrl, { clone: false }, function (err) { console.log(err) })
downgit
方法里面的第一个参数理解为在github上面下载kongcodes用户的vue3-vant
项目模板。第二个参数downUrl
为要将模板下载到什么目录下。第三个参数clone
是否要用git clone
下载。第四个参数 为下载完成执行的一些事情。
command
方法使用commander.command("create <projectName>").action((projectName) => { const spinner = ora({ text: "正在下载https://github.com/kongcodes/vue3-vant..." }); spinner.start(); fs.mkdirSync(`./${projectName}`); const downUrl = `${process.cwd()}\\${projectName}`; downgit("github:kongcodes/vue3-vant", downUrl, { clone: false }, function (err) { if (err) throw err; spinner.stop(); console.log(chalk.green("downgit success")); }) })
执行 mycli create pro
回车,会在当前目录下创建pro
目录,下载vue3-vant
模板到这个目录里。
https://github.com/kongcodes/mycli
更多node相关知识,请访问:nodejs 教程!
위 내용은 mycli 명령줄 도구의 노드 실제 개발의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!