模块 /node_modules/angular2-cool-storage/index.d.ts 的元数据版本不匹配,发现版本为4,预期为3,出现了错误。

7

在运行ng build命令时,我遇到了以下错误。 已删除node_modules文件夹并进行npm安装,但收到以下警告:

npm WARN angular2-cool-storage@3.1.2 requires a peer of @angular/core@5.0.0 but none was installed.
npm WARN angular2-cool-storage@3.1.2 requires a peer of @angular/common@^5.0.0 but none was installed.

以下是对 "ng build" 命令出现的错误的翻译:

模块 /node_modules/angular2-cool-storage/index.d.ts 的元数据版本不匹配,找到版本 4,期望版本3,正在解析 /src/app/app.module.ts 中的 AppModule 符号,解析 /src/app/app.module.ts 中的 AppModule 符号时出错。

package.json 文件如下:

{
  "name": "nova-angular",
  "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": "^4.4.3",
    "@angular/cdk": "^2.0.0-beta.12",
    "@angular/common": "^4.4.3",
    "@angular/compiler": "^4.4.3",
    "@angular/core": "^4.4.3",
    "@angular/forms": "^4.4.3",
    "@angular/http": "^4.4.3",
    "@angular/material": "^2.0.0-beta.12",
    "@angular/platform-browser": "^4.4.3",
    "@angular/platform-browser-dynamic": "^4.4.3",
    "@angular/router": "^4.4.3",
    "@ng-bootstrap/ng-bootstrap": "^1.0.0-alpha.29",
    "angular2-cool-storage": "^3.1.0",
    "angular2-jwt": "^0.2.3",
    "bootstrap": "^3.3.7",
    "classlist.js": "^1.1.20150312",
    "core-js": "^2.5.0",
    "ng2-cookies": "^1.0.12",
    "ng2-truncate": "^1.3.10",
    "rxjs": "^5.4.2",
    "tslint-fix": "^0.1.0",
    "zone.js": "^0.8.16"
  },
  "devDependencies": {
    "@angular/cli": "1.3.2",
    "@angular/compiler-cli": "^4.4.3",
    "@angular/language-service": "^4.4.3",
    "@types/jasmine": "~2.5.53",
    "@types/jasminewd2": "~2.0.2",
    "@types/node": "^8.0.26",
    "codelyzer": "^3.1.2",
    "jasmine-core": "~2.8.0",
    "jasmine-spec-reporter": "~4.2.1",
    "karma": "~1.7.0",
    "karma-chrome-launcher": "~2.2.0",
    "karma-cli": "~1.0.1",
    "karma-coverage-istanbul-reporter": "^1.2.1",
    "karma-jasmine": "~1.1.0",
    "karma-jasmine-html-reporter": "^0.2.2",
    "karma-junit-reporter": "^1.2.0",
    "karma-phantomjs-launcher": "^1.0.4",
    "protractor": "~5.1.2",
    "ts-node": "~3.3.0",
    "tslint": "~5.7.0",
    "typescript": "~2.4.2",
    "typings": "^2.1.1"
  }
}

之前我使用的是angular2-cool-storage,现在安装并使用了ng2-cookies后,ng build失败了。请给我建议。


为了保持包的一致性,我更新了我的package.json文件。 从包名中删除了脱字符(^),这样它就不会更新包头了。 它强制npm使用该版本。 "angular2-cool-storage": "^3.1.0" => "angular2-cool-storage": "3.1.0" - mahesh kajale
3个回答

4
似乎存在包兼容性问题,您需要按照指南升级到Angular 5版本以获得与包兼容的版本,我已经尝试过并且效果很好。
``` npm install @angular/animations@^5.0.0 @angular/common@^5.0.0 @angular/compiler@^5.0.0 @angular/compiler-cli@^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 typescript@2.4.2 rxjs@^5.5.2 ```

2

信息很清楚:您需要至少5.0.0版本的angular核心和公共版本。

您的软件包文件显示4.4.3版本。

尝试更新您的软件包或降级您的依赖项,然后再试一次!


谢谢回复。 之前我们使用的是同样的Angular 4和Cool Storage 3.1.0。 现在安装并在代码中使用了ng2-cookies,然后出现了问题。 - mahesh kajale
如果你卸载了 cookies,会发生什么?应用程序会运行吗? - user4676340
不,它不会运行。 那个包被用在应用程序模块内部。 - mahesh kajale
当然,但我的意思是如果你从代码中将其完全删除。这会使我知道问题是否来自于cookie或存储。 - user4676340

1

为了保持包的一致性,我更新了我的package.json文件。 将包名中的脱字符(^)删除,这样就不会更新包头了。 它强制npm仅使用指定的版本。

"angular2-cool-storage": "^3.1.0" => "angular2-cool-storage": "3.1.0"

检查与相同Angular版本兼容的早期软件包版本,并在软件包自动升级时在package.json中指定那些没有^的条目,以避免“元数据版本不匹配”的问题。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接