使用typescript快速开发一个cli的实现示例

作者:Jason Long 时间:2023-08-30 07:25:25 

cli 的全称 command-line interface(命令行界面),也就是前端同学常用的脚手架,比如 yo、vue cli、react cli 等。

cli 可以方便我们快速创建项目,下图是引用 vue cli 的介绍:

使用typescript快速开发一个cli的实现示例

创建项目

运行下面的命令,创建一个项目:

npm init

执行命令完成后,可以看到项目根目录只有一个 package.json 文件。

使用typescript快速开发一个cli的实现示例

在 package.json 文件增加 bin 对象,并指定入口文件 dist/index.js。

在命令行运行需要在入口文件的第一行增加 #!/usr/bin/env node,告诉系统用 node 运行这个文件。

{
"name": "cli-demo",
"version": "0.0.1",
"description": "cli demo",
"keywords": [
"cli"
],
"bin": {
"cli-demo": "dist/index.js"
}
...
}

安装依赖

命令行工具,也会涉及到用户交互的动作,那么 node.js 是怎么实现呢?早有大佬提供了非常好的库,我们只要拿过来用,主要有两个库:

  • commander:完整的 node.js 命令行解决方案。

  • inquirer:交互式命令行工具。

将这两个库安装到项目里:

yarn add commander inquirer

由于是用 typescript 开发,再通过 rollup 打包,先安装相关的依赖库:

yarn add typescript rollup rollup-plugin-terser rollup-plugin-typescript2 @types/inquirer -D

配置

由于是用 typescript 开发,首先需要配置一下 tsconfig.json。

{
"compilerOptions": {
"target": "ES6",
"module": "ESNext",
"sourceMap": false,
"declaration": false,
"outDir": "./dist",
"moduleResolution": "Node",
"esModuleInterop": true,
"resolveJsonModule": true,
"removeComments": false,
"importHelpers": true,
"strict": true,
"lib": ["ES6", "DOM"]
},
"include": ["src"]
}

接下来在根目录增加一个 rollup.config.js,把 typescript 代码编译成 javascript 代码。前面提到的要在第一行增加 #!/usr/bin/env node 来告诉系统用 node 运行,那么可以在 rollup.config.js 的 banner 选项,把 #!/usr/bin/env node 写在最前面。

import typescript from 'typescript'
import json from '@rollup/plugin-json'
import { terser } from 'rollup-plugin-terser'
import typescript2 from 'rollup-plugin-typescript2'
import { dependencies } from './package.json'
const external = Object.keys(dependencies || '')
const globals = external.reduce((prev, current) => {
const newPrev = prev
newPrev[current] = current
return newPrev
}, {})
const defaultConfig = {
input: './src/index.ts',
output: {
file: './dist/index.js',
format: 'cjs',
banner: '#!/usr/bin/env node',
globals
},
external,
plugins: [
typescript2({
 exclude: 'node_modules/**',
 useTsconfigDeclarationDir: true,
 typescript,
 tsconfig: './tsconfig.json'
}),
json(),
terser()
]
}
export default defaultConfig

实现一个简单的 cli

在根目录创建一个 src 文件夹,然后再创建一个 index.ts

添加引用

添加引用并实例化 Command 对象。

import { Command } from 'commander'
import pkg from '../package.json'
const program = new Command(pkg.name)

自定义命令

实现一个可交互的自定义命令,模拟在终端(命令行)的登录功能。使用 command 方法创建一个命令,description 可以用来描述这个命令的作用,登录处理逻辑则写在 action 方法里。最后使用 parse(process.argv) 方法,解析命令。更多详细介绍和使用,可移步:https://github.com/tj/commander.js/blob/master/Readme_zh-CN.md。

program
.command('login')
.description('模拟登录。')
.action(() => {
 handleLogin()
})
program.parse(process.argv)

交互的话,用到前面说的 inquirer 库,接收输入的用户名和密码。选项的 type 的值有 inputpasswordnumbercheckboxeditorlistrawListexpandconfirm,选项 nameinquirer.prompt 方法返回的对象,选项 validate 可用来验证输入是否符合规则。更多详细介绍和使用,可移步:https://github.com/SBoudrias/Inquirer.js/blob/master/README.md

如果选项 typepassword,可通过 mask 设置掩码。

const handleLogin = () => {
// 配置交互的用户名和密码
const prompt = [
{
 type: 'input',
 name: 'userName',
 message: '用户名:',
 validate: (value: string) => value.length > 0 || '用户名不能为空'
},
{
 type: 'password',
 name: 'password',
 message: '密码:',
 mask: '🙈 ',
 validate: (value: string) => value.length > 0 || '密码不能为空'
}
]
inquirer.prompt(prompt).then(({ userName, password }) => {
if (userName === 'demo' || password === '123456') {
 console.log('登录成功')
 return
}
console.log('用户名或密码错误')
})
}

其他

一个 cli 工具,帮助信息也是必须的,可以通过 on('--help') 修改自定义帮助信息。

必须在 parse 方法之前。

program.on('--help', () => {
console.log('\n运行 cli-demo -h | --help 查看命令使用。\n')
})

然后再来修改一下,没有输入任何参数的时候,会出现错误,可以使用 exitOverride 方法重新退出,在终端(命令行)输出帮助信息。

program.exitOverride()
try {
program.parse(process.argv)
} catch (error) {
program.outputHelp()
}

到这里,一个简单的 cli 工具完成了,先本地来测试下看看。在终端(命令行)输入 npm link,生成一个全局软连接,可以方便调试和测试。

使用typescript快速开发一个cli的实现示例

来源:https://www.cnblogs.com/JasonLong/p/14075724.html

标签:typescript,cli
0
投稿

猜你喜欢

  • MYSQL 字符串操作

    2008-11-13 12:34:00
  • Pytorch PyG实现EdgePool图分类

    2022-03-17 15:47:55
  • 浅谈Python中带_的变量或函数命名

    2023-08-30 15:44:08
  • python使用pip安装模块出现ReadTimeoutError: HTTPSConnectionPool的解决方法

    2023-07-07 02:41:30
  • python可视化爬虫界面之天气查询

    2022-09-24 07:34:54
  • Python Base64编码和解码操作

    2022-10-20 06:26:05
  • 在Python中使用cookielib和urllib2配合PyQuery抓取网页信息

    2023-10-12 14:15:19
  • Opencv图像添加椒盐噪声、高斯滤波去除噪声原理以及手写Python代码实现方法

    2021-12-30 00:21:40
  • 关于数据处理包dplyr的函数用法总结

    2023-06-11 06:23:13
  • javascript操作向表格中动态加载数据

    2024-04-27 15:21:09
  • python超详细实现完整学生成绩管理系统

    2022-08-25 08:59:08
  • Python extract及contains方法代码实例

    2021-03-29 07:51:25
  • 分析Python的Django框架的运行方式及处理流程

    2022-03-13 14:47:50
  • Oracle中锁(lock)的用法

    2024-01-12 17:22:49
  • Pycharm2022最新版无法换源解决方法

    2023-02-09 20:51:55
  • JS实现判断有效的数独算法示例

    2024-02-25 08:22:15
  • python编程之requests在网络请求中添加cookies参数方法详解

    2023-07-03 00:48:23
  • javascript 版 Bad Apple 字符动画

    2010-01-28 12:19:00
  • Python字符串处理实现单词反转

    2021-01-30 19:19:01
  • JavaScript 中获取数组最后一个元素方法汇总

    2024-06-07 15:25:25
  • asp之家 网络编程 m.aspxhome.com