模块node_modules / angular-2-local-storage / dist / index.d.ts的元数据版本不匹配,找到版本4,预计为3

时间:2018-05-27 09:47:35

标签: angular angular-local-storage

我正在使用Angular2应用程序并使用npm start命令获得以下错误。 这是完整的代码 模块中的错误元数据版本不匹配/home/x/Desktop/koohbaad-web/node_modules/angular-2-local-storage/dist/index.d.ts,找到版本4,预期3,解决/ home /中的符号AppModule x / Desktop / koohbaad-web / src / app / app.module.ts,解析/home/x/Desktop/koohbaad-web/src/app/app.module.ts中的符号AppModule,解析/ home /中的符号AppModule X /桌面/ koohbaad幅/ SRC /应用/ app.module.ts

这是我的package.json文件

{
  "name": "koohbad-tour",
  "version": "0.0.0",
  "license": "MIT",
  "scripts": {
    "ng": "ng",
    "start": "ng serve --host 192.168.1.193",
    "build": "ng build",
    "test": "ng test",
    "lint": "ng lint",
    "e2e": "ng e2e"
  },
  "private": true,
  "dependencies": {
    "@agm/core": "^1.0.0-beta.0",
    "@angular/animations": "^4.*",
    "@angular/common": "^4.0.0",
    "@angular/compiler": "^4.0.0",
    "@angular/core": "^4.0.0",
    "@angular/forms": "^4.0.0",
    "@angular/http": "^4.0.0",
    "@angular/platform-browser": "^4.0.0",
    "@angular/platform-browser-dynamic": "^4.0.0",
    "@angular/router": "^4.0.0",
    "@types/underscore": "^1.8.0",
    "angular-2-local-storage": "*",
    "angular-star-rating": "^3.0.8",
    "angular2-masonry": "^0.4.0",
    "angular2-recaptcha": "*",
    "angular2-text-mask": "^8.0.1",
    "core-js": "^2.4.1",
    "enhanced-resolve": "^3.3.0",
    "jquery": "^3.2.1",
    "ng-lazyload-image": "^3.3.3",
    "ng-select": "^1.0.0-beta.5",
    "ng2-select2": "^1.0.0-beta.10",
    "ngx-infinite-scroll": "^0.5.1",
    "node-sass": "^4.7.2",
    "rxjs": "^5.1.0",
    "screenfull": "^3.3.1",
    "underscore": "*",
    "web-animations-js": "^2.2.5",
    "zone.js": "^0.8.4",
    "ngx-swiper-wrapper": "4.0.0"
  },
  "devDependencies": {
    "@angular/cli": "1.0.0",
    "@angular/compiler-cli": "^4.0.0",
    "@types/jasmine": "2.5.38",
    "@types/jquery": "^2.0.42",
    "@types/node": "~6.0.60",
    "codelyzer": "~2.0.0",
    "jasmine-core": "~2.5.2",
    "jasmine-spec-reporter": "~3.2.0",
    "karma": "~1.4.1",
    "karma-chrome-launcher": "~2.0.0",
    "karma-cli": "~1.0.1",
    "karma-coverage-istanbul-reporter": "^0.2.0",
    "karma-jasmine": "~1.1.0",
    "karma-jasmine-html-reporter": "^0.2.2",
    "ngx-dropzone-wrapper": "^4.0.3",
    "protractor": "~5.1.0",
    "ts-node": "~2.0.0",
    "tslint": "~4.5.0",
    "typescript": "~2.2.0"
  }
}

我得到的错误是

  

模块node_modules / angular-2-local-storage / dist / index.d.ts的元数据版本不匹配中的错误,找到版本4,预期3   enter image description here

请帮帮我。

4 个答案:

答案 0 :(得分:2)

您的package.json文件有错误,angular-2-local-storage中没有版本号。它应该是"angular-2-local-storage": "^2.0.0"

之后请尝试删除node_modules目录并再次安装npm。

答案 1 :(得分:2)

这是因为使用Angular 5构建了angular-2-local-storage并生成了版本4的元数据文件(编译器无法理解,因为您的angular 4项目只能读取版本3之前的元数据文件) 我建议您将项目更新为Angular 5,然后重试

答案 2 :(得分:1)

发生Angular-2-local-storage错误,因为在package.json文件中,此依赖项具有空值,并且此依赖项的预期版本为3。 因此,请尝试使用命令 npm install dependencyName 再次安装此依赖项。 (在您的情况下,依赖关系是angular-2-local-storage)

如果没有成功,则显式修改package.json以获取angular2-local-storage并为其赋值3.0

关于node-sass错误,这是我们第一次在机器上创建新项目时得到的。当我第一次安装角度cli时,我发生了一个猜测,并使用ng服务运行应用程序。我认为这是一个非更新模块或cli的问题。

尝试更新节点模块,angular-cli然后运行应用程序。 如果问题仍然存在,那么转到github页面为angular,我认为这个问题已被列出。

答案 3 :(得分:-2)

如果由于某种原因(时间)您无法将Angular 4项目更新到Angular 5,我建议您使用这种方法来解决此错误而不进行迁移。使用修复失配实用程序来更改元数据文件的版本。

  1. 在Angular 4项目中安装修复失配模块作为开发依赖项

    npm i @jagcolombat/repair-mismatch --save-dev

  2. 创建一个文件JavaScript,例如rpmm.js,并输入以下代码段:

    const rpmm = require('repair-mismatch');
    rpmm({ modules: ['ngx-vis'] });

注意:在这种情况下,我使用ngx-vis@1.0.1(与Angular 6编译),并且我想在Angular 4项目中使用它。

  1. 运行此命令以更改指定模块(ngx-vis)中的元数据版本

    node rpmm.js

有关更多详细信息,请阅读本文:

https://medium.com/@tonytunes2005/solving-error-mismatch-beetwen-angular-versions-b051e7cde418