NPM不会安装所有依赖项

NPM不会安装所有依赖项,npm,angular-cli,Npm,Angular Cli,我有一个看起来很奇怪的问题。因此,我目前正在开发一个angular应用程序,一位朋友用zip文件发送给我,其中包含文件夹节点模块(这很重要)。当我用ng-serve启动它时,一切都很完美。因此,现在我删除了node_module文件夹,然后运行npm install然后运行ng serve,现在我缺少了一些组件,比如导航栏,我的应用程序的某些部分看起来不像应该的那样 以下是package.json: { "name": "iot-cm", "version": "0.0.0", "l

我有一个看起来很奇怪的问题。因此,我目前正在开发一个angular应用程序,一位朋友用zip文件发送给我,其中包含文件夹节点模块(这很重要)。当我用
ng-serve
启动它时,一切都很完美。因此,现在我删除了node_module文件夹,然后运行
npm install
然后运行
ng serve
,现在我缺少了一些组件,比如导航栏,我的应用程序的某些部分看起来不像应该的那样

以下是package.json:

{
  "name": "iot-cm",
  "version": "0.0.0",
  "license": "MIT",
  "scripts": {
    "ng": "ng",
    "start": "ng serve",
    "build": "ng build",
    "test": "ng test",
    "lint": "ng lint",
    "e2e": "ng e2e"
  },
  "private": true,
  "dependencies": {
    "@angular/animations": "^5.0.0",
    "@angular/common": "^5.0.0",
    "@angular/compiler": "^5.0.0",
    "@angular/core": "^5.0.0",
    "@angular/forms": "^5.0.0",
    "@angular/http": "^5.0.0",
    "@angular/platform-browser": "^5.0.0",
    "@angular/platform-browser-dynamic": "^5.0.0",
    "@angular/platform-server": "^5.0.0",
    "@angular/router": "^5.0.0",
    "@ng-bootstrap/ng-bootstrap": "^1.0.0-beta.9",
    "angular": "^1.6.8",
    "angular-font-awesome": "^3.1.2",
    "angularfire2": "^5.0.0-rc.6",
    "bootstrap": "^4.0.0-alpha.6",
    "core-js": "^2.4.1",
    "firebase": "^4.9.1",
    "font-awesome": "^4.7.0",
    "jquery": "^3.2.1",
    "ng-http-loader": "^0.6.0",
    "ng2-loading-animate": "0.0.17",
    "rxjs": "^5.1.0",
    "zone.js": "^0.8.4"
  },
  "devDependencies": {
    "@angular/cli": "^1.6.4",
    "@angular/compiler-cli": "^5.0.0",
    "@angular/language-service": "^4.0.0",
    "@ngtools/webpack": "^1.9.4",
    "@types/jasmine": "2.5.45",
    "@types/node": "~6.0.60",
    "codelyzer": "~3.0.1",
    "jasmine-core": "~2.6.2",
    "jasmine-spec-reporter": "~4.1.0",
    "karma": "~1.7.0",
    "karma-chrome-launcher": "~2.1.1",
    "karma-cli": "~1.0.1",
    "karma-coverage-istanbul-reporter": "^1.2.1",
    "karma-jasmine": "~1.1.0",
    "karma-jasmine-html-reporter": "^0.2.2",
    "protractor": "~5.1.2",
    "ts-node": "~3.0.4",
    "tslint": "~5.3.2",
    "typescript": "^2.4.2",
    "webpack": "^3.10.0"
  }
}

如果有人知道这会很好,因为我显然不想将node_modules文件夹推到我的git中。

package.json是一个文件,它知道您的依赖项是什么。你需要跑步

npm安装


该文件的全部目的是不必共享该特定文件夹,而是能够复制该过程。install命令将重新安装您的依赖项,以重新创建node_modules文件夹。

可能有一百万个原因。其中之一可能是代码使用了一个被提升的依赖项。npm创建一个平面节点_modules,因此代码可以访问package.json中未声明的包。我在以下文章中提到了平面节点_模块的这一糟糕特性:

当然,如果您的朋友在项目中提供了
package lock.json
文件,这种情况就不会发生


另一个可能的原因(但不太可能)可能是您将npm配置设置为
true
,而您的朋友没有设置。

我成功地解决了我的问题:

删除
包锁.json

运行:
npm安装-g npm collect
此模块允许您从node\u modules文件夹生成package.json文件

运行:
npm collect--new--save


然后你的package.json是最新的,一切都按预期运行。

是的,请再次阅读这篇文章,我忘了在ng serve xDUps之前运行npm安装。也许你的朋友在使用Thread?不,他告诉我他在使用npm,所以现在我想他安装了一个模块,但没有将依赖项写入package.json文件,但我怎么知道缺少哪个模块?抱歉,回答太晚了。在这种情况下,我会检查chrome中的错误日志或您正在测试的任何地方,或者查看失败的代码。一定有一个变量或函数名会给你一个提示。谢谢你的回答,我的朋友实际上给了我package-lock.json!我确信我的npm没有被配置成全球风格,尽管他可能是。