🔧 手把手教你开发一个自己的cli工具(二)

前言

🔧 手把手教你开发一个自己的cli工具(一)juejin.cn/post/735946...

这里呢,我准备分享一下如何开发自己的cli工具,以及介绍一下cli工具的具体能做哪些事情

生成全局变量

首先在package.json中添加bin

json 复制代码
  "bin": {
    "full-featured-commit": "./bin/index.js"
  },

然后npm link在全局生成软链,这个link软链在window系统可能会有坑,大家自行搜索吧,我这里是macOS,软链npm link应该是不生效的,所以这里可以全局安装路径下的包

sh 复制代码
# 获取到当前项目目录
pwd
# User/xxx/xxx/xxx

#全局安装
npm install -g User/xxx/xxx/xxx

然后在终端运行一下,这样就可以了

编写commander命令

我们先创建一个program,然后编写一下基本的信息,然后运行即可

arduino 复制代码
  program
    .name('🌸 10:30的飞机 🌸')
    .version('🌈 1.4.1', '-v,--version')
    .description('🚀 南宁的朋友')
  program.parse()

然后就是一些基础命令用法这里大家直接去官网看就可以啦www.npmjs.com/package/com...

inquirer

inquirer 是问答交互命令行生成工具,这里大家去官方文档查看即可www.npmjs.com/package/inq...

js 复制代码
import inquirer from 'inquirer'
const prompt = inquirer.createPromptModule()

propt([{
        type: 'confirm',
        name: 'isGit',
        message: 'Are you going to use git in your project?',
        default: true
},
{
        type: 'confirm',
        name: 'isEslintAndPrettier',
        message:'Are you going to use Eslint and Prettier in your project?',
        default: true
}
]).then(res=>{
 console.log(res)
})

chalk

给node.js的命令行添加颜色,使得命令行更加好看,这里照样给大家把地址贴上www.npmjs.com/package/cha...

hirestime

用于计算某个函数从开始到结束所需要的时间www.npmjs.com/package/hir...

figlet

用于在命令行生成艺术字,让我们的终端命令更加好看 www.npmjs.com/package/fig...

发布到npm

首先在npm官网注册一个账号,然后我们就可以发布包了

先用终端打开项目根目录文件,然后查看当前的npm源是否是官网,注意:这里必须是官网,如果不是官方源的话,会出错,所以这里大家都切换到官网源,

arduino 复制代码
npm config get registry

npm  config get registry https://registry.npmjs.org/

然后执行npm login

sh 复制代码
npm login

npm publish

这样之后就能发布在npm上了。完成之后就大功告成了,注意一般最新版本只在官方源能download到,别的源拉取官方源有一定的延时

🔧 手把手教你开发一个自己的cli工具(一)juejin.cn/post/735946...

相关推荐
茶卡盐佑星_2 分钟前
说说你对es6中promise的理解?
前端·ecmascript·es6
Манго нектар30 分钟前
JavaScript for循环语句
开发语言·前端·javascript
蒲公英100138 分钟前
vue3学习:axios输入城市名称查询该城市天气
前端·vue.js·学习
天涯学馆1 小时前
Deno与Secure TypeScript:安全的后端开发
前端·typescript·deno
以对_1 小时前
uview表单校验不生效问题
前端·uni-app
程序猿小D2 小时前
第二百六十七节 JPA教程 - JPA查询AND条件示例
java·开发语言·前端·数据库·windows·python·jpa
奔跑吧邓邓子2 小时前
npm包管理深度探索:从基础到进阶全面教程!
前端·npm·node.js
前端李易安3 小时前
ajax的原理,使用场景以及如何实现
前端·ajax·okhttp
汪子熙3 小时前
Angular 服务器端应用 ng-state tag 的作用介绍
前端·javascript·angular.js
Envyᥫᩣ3 小时前
《ASP.NET Web Forms 实现视频点赞功能的完整示例》
前端·asp.net·音视频·视频点赞