我正在使用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
请帮帮我。
答案 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,我建议您使用这种方法来解决此错误而不进行迁移。使用修复失配实用程序来更改元数据文件的版本。
在Angular 4项目中安装修复失配模块作为开发依赖项
npm i @jagcolombat/repair-mismatch --save-dev
创建一个文件JavaScript,例如rpmm.js,并输入以下代码段:
const rpmm = require('repair-mismatch');
rpmm({ modules: ['ngx-vis'] });
注意:在这种情况下,我使用ngx-vis@1.0.1(与Angular 6编译),并且我想在Angular 4项目中使用它。
运行此命令以更改指定模块(ngx-vis)中的元数据版本
node rpmm.js
有关更多详细信息,请阅读本文:
https://medium.com/@tonytunes2005/solving-error-mismatch-beetwen-angular-versions-b051e7cde418