上篇文章已经讲过如何在
npm
发布一个自己的项目用于使用。
本篇文章致力于讲解如何制作一个带有全局命令的项目。
发布带有全局命令的项目
如vue-cli,类型的,不过我们还是循序渐进,慢慢前行。
1、创建一个项目,使用npm init -y
来初始化项目
2、新建bin
目录,在bin目录下书写index.js
文件
3、index.js
文件中最顶部书写 #!/usr/bin/env node
(环境变量中注入)
4、在npm 进行发布
5、全局安装,注意,发布时如果在项目下进行发布后,并且在当前目录的外部进行npm install -g xx
进行安装,那么查看环境变量,它会软链至当前项目,方便后续继续开发。如果在其它目录 进行全局安装,那么它是以外链至npm的方式和当前项目无关。
6、可以在index.js目录下通过process.env.argv 来获取用户的输入,根据输入进行相应的响应即可。
![](https://img.haomeiwen.com/i2004452/f9f0dc7521e41764.png)
![](https://img.haomeiwen.com/i2004452/1d13755930a6c9a1.png)
环境中注入
若是有使用过Linux或者Unix的前端开发者,对于Shebang应该不陌生,它是一个符号的名称,#!
。这个符号通常在Unix系统的基本中第一行开头中出现,用于指明这个脚本文件的解释程序。了解了Shebang之后就可以理解,增加这一行是为了指定用node执行脚本文件。
当你输入一个命令的时候,npm是如何识别并执行对应的文件的呢?具体的原理阮一峰大神已经在npm scripts 使用指南中介绍过。简单的理解,就是输入命令后,会有在一个新建的shell中执行指定的脚本,在执行这个脚本的时候,我们需要来指定这个脚本的解释程序是node。
为了解决这个问题,首先需要了解一下/usr/bin/env
。我们已经知道,Shebang是为了指定脚本的解释程序,可是不同用户或者不同的脚本解释器有可能安装在不同的目录下,系统如何知道要去哪里找你的解释程序呢? /usr/bin/env
就是告诉系统可以在PATH目录中查找。 所以配置#!/usr/bin/env node
, 就是解决了不同的用户node路径不同的问题,可以让系统动态的去查找node来执行你的脚本文件。
看到这里你应该理解,为什么会出现No such file or directory
的错误?因为你的node安装路径没有添加到系统的PATH
中。所以去进行node环境变量配置就可以了。
要是你只是想简单的测试一下,那么你可以通过which node命令来找到你本地的node安装路径,将/usr/bin/env
改为你查找到的node路径即可。
最后需要说明的一点是,windows不支持Shebang,它是通过文件的扩展名来确定使用什么解释器来执行脚本。
网友评论