十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
小编给大家分享一下怎么制作CLI可能用到的轮子,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
在鼓楼等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供成都网站设计、成都网站制作 网站设计制作按需求定制设计,公司网站建设,企业网站建设,品牌网站制作,全网整合营销推广,外贸网站建设,鼓楼网站建设费用合理。
开始之前先要了解npm的bin用法。
"bin": {
"init": "index.js"
}
执行npm install -g就在全局安装了init命令,在CMD里就可以执行init。
执行之后,由于在我本机目前默认是由VS Code打开JavaScript文件,所以效果并不是执行代码(这个问题下文有继续,千万别走开,有个坑)。从上面日志打印可以看出,实际上Node.js相当于建立了一个快捷方式,init指向安装到全局模块的该工程的index.js,而init是被加入了到环境变量PATH可以直接执行。
也可以使用npm link直接将index.js链接到PATH里,但先要npm uninstall -g卸载一下,否则会报重复了的错误。
现在正式开始观赏轮子,以下排名不分先后。
command.js
command.js可以和刚才bin生成的全局命令一起配合使用,有一个优势是它居然还有中文文档,虽然E文对我来说不是难事,但是中文的还是读起来快多了。
const { program } = require("commander");
program
.version("0.0.1")
.arguments("
.description('Login Module')
.option("-u, --username
.option("-p, --password
.action(function (file) {
console.log(program.opts());
console.log(file);
})
.parse(process.argv);
一开始使用全局命令不能接受参数而直接使用Node.js执行是可以的。
后来找了下,原来主入口文件开头的#! /usr/bin/env node是必须的,加入后变为
#! /usr/bin/env node
const { program } = require("commander");
program
.version("0.0.1")
.arguments("
.description("Login Module")
.option("-u, --username
.option("-p, --password
.action(function (file) {
console.log(program.opts());
console.log(file);
})
.parse(process.argv);
再次执行(有可能需要重新npm [un]install -g或者npm [un]link),这次OK了
arguments里带<>的参数表示是必须的,如果缺失,就不能继续进行。
参数里要定义必填项使用。requiredOption,比如program.requiredOption('-c, --cheese
commander.js根据参数也自动帮你生成了帮助命令init --help
更详细的用法请参考官方文档。
svg-term-cli
svg-term-cli用来生成ascii码动画的SVG文件。它需要全局安装
npm install -g svg-term-cli
现在从https://asciinema.org/a/113643上生成SVG动图
svg-term --cast 113643 --out examples/parrot.svg --window --no-cursor --from=4500
结束后会在examples下生成一个parrot.svg的文件,打开这个文件看看,太浪了
progress
progress用来生成一个等待进度条。
var ProgressBar = require("progress");
var bar = new ProgressBar(":bar", { total: 40 });
var timer = setInterval(function () {
bar.tick();
if (bar.complete) {
console.log("\ncomplete\n");
clearInterval(timer);
}
}, 1000);
生成如下的进度条
我们常见的下载进度展示,就可以用它来实现
ora
对于不确定的进度情况,就可以使用ora了。它就是那种爱的魔力转圈圈的样式。
const ora = require("ora");
const spinner = ora("Loading unicorns")。start();
setTimeout(() => {
spinner.color = "yellow";
spinner.text = "Loading rainbows";
}, 1000);
setTimeout(() => {
spinner.fail();
}, 3000);
以上是“怎么制作CLI可能用到的轮子”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!