npm run xxx底层到底干了啥

首先,我们要了解,npm run xxx是npm CLI的一个。官网:https://docs.npmjs.com/cli/v9/commands/npm-run-script

命令(其全名是run-script,有三个别名run、rum、urn):

npm run-script <command> [-- <args>]

aliases: run, rum, urn

其运行时会去当前路径下的package.json中找到对应的script

  "scripts": {
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "lint": "vue-cli-service lint"
  },
  

使用npm run script执行脚本的时候都会创建一个shell,然后在shell中执行指定的脚本。
这个shell会将当前项目的可执行依赖目录(即node_modules/.bin)添加到环境变量path中,当执行之后之后再恢复原样。就是说脚本命令中的依赖名会直接找到node_modules/.bin下面的对应脚本,而不需要加上路径。

比如我们执行 npm run-script build ,其会创建一个shell,在这个新的shell中执行脚本,并且吧node_modules/.bin/加入PATH中,其对应的命令是 vue-cli-service build ,然后,我们去node_modules/.bin/路径下就会找到这个命令,那这个命令是

那node_modules/.bin下的脚本是什么时候放进去的呢?npm 在执行install的时候,会根据三方库中的package.json里面的bin配置,在node_modules下面的.bin目录生成一个可执行文件例如下图 。

生成的可执行文件其实是一个替身文件,那么这个替身文件真正指向的就是package.json里面的bin配置里面的那个文件。

举例

目前手上一个项目,当我们需要打包时,我们执行 npm rum build:prod ,我们了解了其运行原理之后,就可以如下方式运行打包

.\node_modules\.bin\vue-cli-service.cmd build

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值