无法解析依赖项:npm ERR!同行@angular/compiler@"11.2.8"

And*_*Guy 4 angular-cli angular-compiler

我正在尝试让我的应用程序部署在 Heroku 上。我收到了“sh: 1: ng: not found”错误,但根据这里的回复,我移动了我的@angular/cli、@angular-devkit/build-angular、@angular/compiler-cli 和 typescript。现在我收到“无法解析依赖项:npm ERR!peer @angular/compiler@"11.2.8"”错误。我认为它有一个版本问题?我不确定发生了什么。

我试过运行 'npm update' 并尝试手动将 '@angular/compiler@"11.2.8"' 插入依赖项,然后运行 ​​'npm i' 但两者都给我同样的错误。

这是我的错误:

npm ERR! Found: @angular/compiler@11.0.9
npm ERR! node_modules/@angular/compiler
npm ERR!   @angular/compiler@"~11.0.1" from the root project
npm ERR!
npm ERR! Could not resolve dependency:
npm ERR! peer @angular/compiler@"11.2.8" from @angular/compiler-cli@11.2.8
npm ERR! node_modules/@angular/compiler-cli
npm ERR!   dev @angular/compiler-cli@"^11.0.9" from the root project
npm ERR!   peer @angular/compiler-cli@"^11.0.0" from @angular-devkit/build-angular@0.1100.7
npm ERR!   node_modules/@angular-devkit/build-angular
npm ERR!     @angular-devkit/build-angular@"~0.1100.2" from the root project
Run Code Online (Sandbox Code Playgroud)

包.json:

"scripts": {
    "ng": "ng",
    "start": "ng serve",
    "build": "ng build",
    "test": "ng test",
    "lint": "ng lint",
    "e2e": "ng e2e",
    "postinstall": "ngcc"
  },
  "private": true,
  "dependencies": {
    "@angular-devkit/build-angular": "~0.1100.2",
    "@angular/animations": "~11.0.1",
    "@angular/cdk": "^11.2.6",
    "@angular/cli": "~11.0.2",
    "@angular/common": "~11.0.1",
    "@angular/compiler": "~11.0.1",
    "@angular/core": "~11.0.1",
    "@angular/flex-layout": "^11.0.0-beta.33",
    "@angular/forms": "~11.0.1",
    "@angular/material": "^11.2.6",
    "@angular/platform-browser": "~11.0.1",
    "@angular/platform-browser-dynamic": "~11.0.1",
    "@angular/router": "~11.0.1",
    "angular-in-memory-web-api": "^0.11.0",
    "rxjs": "~6.6.0",
    "tslib": "^2.0.0",
    "typescript": "~4.0.2",
    "uuid": "^3.4.0",
    "zone.js": "~0.10.2"
  },
  "devDependencies": {
    "@angular-devkit/build-angular": "~0.1100.2",
    "@angular/cli": "~11.0.2",
    "@angular/compiler-cli": "^11.0.9",
    "@types/jasmine": "~3.6.0",
    "@types/node": "^12.11.1",
    "codelyzer": "^6.0.0",
    "jasmine-core": "~3.6.0",
    "jasmine-spec-reporter": "~5.0.0",
    "karma": "~5.1.0",
    "karma-chrome-launcher": "~3.1.0",
    "karma-coverage": "~2.0.3",
    "karma-jasmine": "~4.0.0",
    "karma-jasmine-html-reporter": "^1.5.0",
    "protractor": "~7.0.0",
    "ts-node": "~8.3.0",
    "tslint": "~6.1.0",
    "typescript": "~4.0.2"
  }
Run Code Online (Sandbox Code Playgroud)

如何解决此错误?

小智 35

听起来像是对等依赖项的问题,请尝试使用npm install --legacy-peer-deps.

  • 这给了我一个“错误:worker #1 上的错误:TypeError:compiler_1.devOnlyGuardedExpression 不是函数”错误 (2认同)

Jam*_*emp 15

根据npm CLI 配置文档

legacy-peer-deps不建议使用,因为它不会强制peerDependencies执行元依赖项可能依赖的契约。

为了尝试遵循 npm 的建议,--legacy-peer-deps我没有进行设置,而是检查了 package-lock.json 并注意到 devDependency(对于 Angular 相关的包)仍然引用旧版本(在我的例子中是 13.0.1,升级到 13.2) .0)。

我只是删除了 package-lock.json 并运行npm install,它安装了所做的更新ng update @angular/cli @angular/core(对 package.json)。

也没有必要删除node_modules。


Sal*_*med 13

除了使用npm install --save --legacy-peer-deps命令行选项外,还可以将其设置为更永久的配置选项: npm config set legacy-peer-deps true.

如果上述方法不起作用,请尝试删除node_modules文件夹和package-lock.json文件并运行命令npm install

  • @Salahuddin Ahmad,谢谢你第一个解决方案与我合作! (3认同)
  • 我尝试了第二个命令,然后删除了node_modules/package-lock.json,我认为编译器版本控制问题已解决!谢谢你!!不幸的是现在 ng not found 问题又回来了......我会对此做更多研究 (2认同)
  • 我遇到了一个非常相似的问题,第二种方法为我解决了问题。 (2认同)

Ian*_*Ian 6

您可能正在使用较新版本的节点。我使用节点 17 得到了这个。我将节点回滚到 14(项目中最初使用的版本)并且 npm 安装得很好。

我建议以后使用NVM 。您可以将.nvm文件添加到项目中,以便锁定要使用的节点版本。