分享一个关于我自己的命令行工具

demo.gif

是干嘛的

本质就是使用 consloe.log 在控制台输出关于我的个人社交账号链接。比如 github, zhihu, weibo, twitter…,通过命令行得到想要的输出或者使用浏览器打开。

将其封装为工具,也可以在其他 npm 项目中使用。通过 postinstall 输出关于自己的信息(不推荐这样做,自己项目、或者学习目的倒也无所谓)

有什么用

我个人觉得就一个学习用途,或许在和前端朋友沟通中。我可以告诉他使用 npx wxh16144 这个命令快速了解我。其主要目的还是学习为主,比如:

  • 使用 mri 快速分析命令行参数。
  • 使用 chalk 美化控制台输出内容。
  • 使用 open 实现使用浏览器打开我的联系链接。
  • 使用 VSCode 的 github copilot 辅助我编写代码。

这些都平时进收藏夹吃灰的包工具,通过写一个小工具进行一个初体验。本次项目依赖也仅是以上3个NPM包。下面将一下具体细节:

目录结构

├── README.md
├── Wxh16144
├── bin
│   └── index.js
├── index.js
└── package.json
复制代码
  • Wxh16144 纯文本文件,存放一个 logo 字符图案,使用 Text to ASCII Art Generator (TAAG)
  • index.js 输出方法的主要实现。
  • bin/index.js 主要提供给命令行使用。

实现终端输出

这里仅展示 --ersion--help 信息的输出实现。代码也比较简单,详细实现GitHub#L34-L89

if (args.version) {
  console.log(`${chalk.bold(package.name)}: ${chalk.blue('v' + package.version)}`);
  return;
}
if (args.help || Object.keys(links).length === 0) {
  console.log(`
  ${chalk.green(`${package.name} [options]`)}
    -p, --pick [${Object.keys(contactList).join('|')}]
    -o, --open: use default browser to open the link.
    -h, --hidelogo: hide auther logo.
    -s, --speed: set the speed of animation.
    -H, --help: show help.
    -v, --version: show version. ${chalk.blue('v' + package.version)}
    ----------------------------------------
    ${chalk.bold('e.g.')} ${chalk.green(`${package.name} -hop ${Object.keys(contactList)[0]}`)}
  `)
  return;
}
复制代码

对于 logo 的输出则更为简单,直接使用 fs 模块对文件进行读取,然后输出即可。

实现格式化命令行参数

使用 mri 工具可快速分析命令行参数, 详细实现GitHub#L28-L32

const mri = require('mri');
const argv = mri(process.argv.slice(2), {
  alias: { H: 'help', v: 'version', o: 'open', p: 'pick', h: 'hidelogo', s: 'speed' },
  boolean: [...Object.keys(contactList)],
  default: { pick: Object.keys(contactList), speed: Math.floor(1000 / 60) }
});
复制代码

实现命令行功能

在 package.json 文件中添加 bin 字段即可

package.json

{
  "name": "wxh16144",
  "version": "0.0.0",
  "bin": "./bin/index.js",
}
复制代码

bin/index.js

#!/usr/bin/env node
require('../index')()
复制代码

至此,实现了一个关于自己的命令行工具。具体使用效果 issues#1

拓展使用

对于前面提到的如何在其他 NPM 包中通过 npm install 时输出关于自己的信息功能也很简单。

方式一

{
  "script":{
    "postinstall":"wxh16144 -hp github"
  }
}
复制代码

方式二

因为在前面对 index.js 中的方法进行了模块导出,所以也可以直接引入 wxh16144 进行调用。我在这里提供了注释 bin/index.js#L4-L6

script/install.js

require('wxh16144')({ hidelogo: true, pick: ['github'] });

// do something
复制代码
{
  "script":{
    "postinstall":"node script/install.js"
  }
}
复制代码

写在最后

以上代码仅提供思路,具体完整代码可以查看 Github Repo。相信代码阅读起来还是挺轻松的。

另外说一点,可以考虑使用 Docker 创建 npm 私服 进行发包测试, 满意后再推送到 npmjs 官方市场。这样可以减少坏的 npm 包出现。(自己强迫症太严重了)

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享