【问题标题】:can't find compiler ngcc module after upgrading Angular and project升级Angular和项目后找不到编译器ngcc模块
【发布时间】:2019-10-18 13:00:33
【问题描述】:

我刚刚将 Angular cli 和我的一个项目从 7.0.7 升级到 7.1.0。

我已关注this post@Francesco Borzi's 的回答。

现在我尝试使用以下方式运行我的项目:

ng serve --proxy-config proxy.conf.json

收到这条消息

找不到模块'@angular/compiler-cli/ngcc' 错误:找不到

模块'@angular/compiler-cli/ngcc'

at Function.Module._resolveFilename (internal/modules/cjs/loader.js:649:15)

at Function.Module._load (internal/modules/cjs/loader.js:575:25)

at Module.require (internal/modules/cjs/loader.js:705:19)

at require (internal/modules/cjs/helpers.js:14:16)

at Object.<anonymous> (/Users/path/myproject/node_modules/@ngtools/webpack/src/ngcc_processor.js:10:16)

at Module._compile (internal/modules/cjs/loader.js:799:30)

at Object.Module._extensions..js (internal/modules/cjs/loader.js:810:10)

at Module.load (internal/modules/cjs/loader.js:666:32)

at tryModuleLoad (internal/modules/cjs/loader.js:606:12)

at Function.Module._load (internal/modules/cjs/loader.js:598:3)

at Module.require (internal/modules/cjs/loader.js:705:19)

at require (internal/modules/cjs/helpers.js:14:16)

at Object.<anonymous> (/Users/path/myproject/node_modules/@ngtools/webpack/src/angular_compiler_plugin.js:23:26)

at Module._compile (internal/modules/cjs/loader.js:799:30)

at Object.Module._extensions..js (internal/modules/cjs/loader.js:810:10)

at Module.load (internal/modules/cjs/loader.js:666:32)

这是我的package.json

{
  "name": "myproject",
  "version": "0.0.0",
  "scripts": {
    "ng": "ng",
    "start": "ng serve",
    "build": "ng build",
    "test": "ng test",
    "lint": "ng lint",
    "e2e": "ng e2e"
  },
  "private": true,
  "dependencies": {
    "@angular/animations": "~7.0.0",
    "@angular/cdk": "7.3.7",
    "@angular/common": "~7.0.0",
    "@angular/compiler": "~7.0.0",
    "@angular/core": "~7.0.0",
    "@angular/forms": "~7.0.0",
    "@angular/http": "~7.0.0",
    "@angular/material": "^7.3.7",
    "@angular/platform-browser": "~7.0.0",
    "@angular/platform-browser-dynamic": "~7.0.0",
    "@angular/router": "~7.0.0",
    "angular": "^1.7.8",
    "bootstrap": "^4.3.1",
    "core-js": "^2.5.4",
    "font-awesome": "^4.7.0",
    "hammerjs": "^2.0.8",
    "jquery": "1.9.1",
    "ngx-gallery": "^5.9.1",
    "popper.js": "^2.0.0-next.4",
    "rxjs": "~6.3.3",
    "zone.js": "~0.8.26"
  },
  "devDependencies": {
    "@angular-devkit/build-angular": "^0.800.1",
    "@angular/cli": "^8.0.1",
    "@angular/compiler-cli": "~7.0.0",
    "@angular/language-service": "~7.0.0",
    "@types/jasmine": "~2.8.8",
    "@types/jasminewd2": "~2.0.3",
    "@types/node": "~8.9.4",
    "codelyzer": "~4.5.0",
    "jasmine-core": "~2.99.1",
    "jasmine-spec-reporter": "~4.2.1",
    "karma": "~3.0.0",
    "karma-chrome-launcher": "~2.2.0",
    "karma-coverage-istanbul-reporter": "~2.0.1",
    "karma-jasmine": "~1.1.2",
    "karma-jasmine-html-reporter": "^0.2.2",
    "protractor": "~5.4.0",
    "ts-node": "~7.0.0",
    "tslint": "~5.11.0",
    "typescript": "~3.1.1"
  }
}

【问题讨论】:

    标签: angular npm angular-cli


    【解决方案1】:

    我卸载并重新安装了@angular/cli,但在npm i 上仍然遇到错误。

    所以我改用npm ci(干净安装的缩写),仍然收到手头的错误。

    事情看起来真的很奇怪,所以我采取了似乎可以解决大多数莫名其妙行为的策略:我打开了一个新的终端窗口。这一次,npm ci; ng serve 跑了。

    我希望我对发生的事情有一个解释,但我真的没有。我最好的猜测是缓存了一些不良数据,需要运行新的查找。无论如何,请不要因为缺乏详细说明而放下答案,我发帖是为了那些拼命努力继续工作的人。

    【讨论】:

      【解决方案2】:

      试试下面的: 1- ng serve 不工作或 ngcc 失败只需输入:

      the project folder -- app folder -- node_modules -- @angular -- compiler-cli -- ngcc
      

      并删除 ngcc 锁定文件。然后 ng serve 就可以了。

      【讨论】:

      • 找不到ngcc锁文件怎么办?
      【解决方案3】:

      希望这将解决您的安装相关问题

      ng update @angular/cli @angular/core
      

      【讨论】:

      【解决方案4】:

      在您的 package.json 文件中,将 devDependencies 中的 @angular/cli 版本更改为:

      "@angular/cli": "7.1.0"
      

      您的项目和 devDependency 之间存在版本不匹配。您可能使用过npm audit fix --force 或类似的自动更新命令,它可能更新了“package.json”文件中的 devDependencies。

      您还可以在此处的 devDependencies 中使用 Angular cli 版本 7.3.5。只要确保开发版本和 devDependencies 中提到的版本兼容。请注意,本地 angular/cli 版本在这里并不重要。

      更新:进行更改后,删除“package-lock.json”并删除“node modules”文件夹。运行npm install 重新安装模块。

      【讨论】:

      • 这里有同样的问题。我应该在服务之前先安装/更新 angular-cli 7.1.0 吗?
      • 您不一定非要这样做。但是试一试。但一定要试试这个:删除“package-lock.json”并删除“节点模块”。运行“npm install”再次安装模块。
      【解决方案5】:

      所有这些对我都不起作用,我正在尝试从 Angular 7 升级到 Angular 8,这对我来说是可行的解决方案:

      1. npm 已过时。
      2. npm 更新。
      3. npm install -g npm-check.
      4. npm-check -u --skip-unused.
      5. 使用 npm-check 升级所有过时的包,除了 sass 包。
      6. npm 更新。
      7. 如果您的应用程序中有 ViewChild,请务必将其编辑为 @ViewChild(&lt;name&gt;, {static: true})

      【讨论】:

        【解决方案6】:

        我遇到了同样的错误,并通过更新@angular/cli global 解决了这个问题。 喜欢:

        npm uninstall -g @angular/cli
        npm install -g @angular/cli
        

        然后尝试创建新应用并将一些依赖项从 package.json 文件复制到当前项目,因为 npm install 不安装最新版本的包。那么

        npm install
        

        这解决了我的问题,但后来我找到了这个答案:update angular

        【讨论】:

        • devkit-cli-compiler-cli和angular的语言服务之间有依赖关系吗?
        • 今天我升级到了angular 9,但是我在任何地方都找不到ngcc
        • npm update 和 npm audit fix 应该可以解决问题。
        • 你可以通过npm install -g @angular/cli@latest来完成这个,应该不需要运行uninstall
        猜你喜欢
        • 2020-05-25
        • 2020-06-23
        • 1970-01-01
        • 2014-08-31
        • 2021-12-17
        • 1970-01-01
        • 2021-06-03
        • 2020-05-03
        • 1970-01-01
        相关资源
        最近更新 更多