npm install 原理是什么[已解决]

运行环境

  • windows 10
  • npm 5.6.0

复现

  1. mkdir test
  2. cd test
  3. npm install --save-dev mocha

以上步骤操作下来,会显示安装成功
但是在test文件夹下面没有自动生成node_modules文件夹

解决

  1. mkdir test
  2. cd test\
  3. npm init
  4. npm install --save-dev mocha

只要初始化一下npm,再安装就会自动生成node_modules文件夹

问题
为什么会这样呢?
npm install的整个流程是怎么样的呢?

单从这个问题上来说,-dev依赖于package.json,package.json又必须通过Inti生成.所以会安装失败
根本原因还是对Install的原理不熟悉,这个需要自己看源码
阅读 7.8k
4 个回答

你仔细看下命令行里的信息,第一遍安装会因为缺少 package.json 而失败,第二次才会成功。所以当然第二次能看到 node_modules 而第一次不能。

npm init 会生成 package.json,而 --save-dev 要把包相关的信息记到 package.json 里,所以第一次就会失败;第二次能成功。

其它的原理看源码吧。

不知你接触过git没,我举一个git的例子,看能不能对你有所帮助:

  • 当你在本地新建一个文件夹时,想把这个文件夹的东西放到github或者gitlab等上存起来怎么办?
  • 直接使用git addgit push之类的指令肯定不行,需要先初始化git, 也就是执行git init
  • 之后会在目录下生成一个隐藏的文件夹.git,里面就放置了一些这个项目的git配置信息,包括仓库地址用户名上传方式等等,当然这些配置信息可以修改

npm也是同样的道理,没有初始化,它就不知道干嘛,程序的执行也就没有参照点,而这个参照点就是初始化之后出现的配置文件或者文件夹,或许这个文件夹或者文件是隐藏的,你看不见,但是不同的系统有不同的方式是可以看见的。

作为补充答案,可以参考npm源码中的/lib/install.js.

function install (where, args, cb) {
  if (!cb) {
    cb = args
    args = where
    where = null
  }
  var globalTop = path.resolve(npm.globalDir, '..')
  if (!where) {
    where = npm.config.get('global')
          ? globalTop
          : npm.prefix
  }
  validate('SAF', [where, args, cb])
  // the /path/to/node_modules/..
  var dryrun = !!npm.config.get('dry-run')

  if (npm.config.get('dev')) {
    log.warn('install', 'Usage of the `--dev` option is deprecated. Use `--only=dev` instead.')
  }

  if (where === globalTop && !args.length) {
    args = ['.']
  }
  args = args.filter(function (a) {
    return path.resolve(a) !== npm.prefix
  })

  new Installer(where, dryrun, args).run(cb)
}

package.json 主要记录本地安装包的版本信息,与 node_module里面对应的依赖包对应的。

   npm install Xxx --save 安装模块,并把模块名和版本号添加到dependencies 部分。
 npm install xxx --save-dev 安装模块,把模块名和版本号写在devdependencies部分。

所有 没有 npm init 初始化,没法记录就不会自动生成node_modules了

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进