是干嘛的
本质就是使用 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 包出现。(自己强迫症太严重了)