node_modules/@types/pdfjs-dist/index.d.ts(63,39)中的错误:错误TS2304:找不到名称“未知”

时间:2020-01-07 08:30:57

标签: angular typescript angular6 pdfjs-dist

我在Angular 6项目中使用ng2-pdf-viewer

在项目编译时会出现以下错误 node_modules/@types/pdfjs-dist/index.d.ts(63,39)中的错误:错误TS2304:找不到名称“未知”。 node_modules/@types/pdfjs-dist/index.d.ts(65,34):错误TS2304:找不到名称“未知”。 node_modules/@types/pdfjs-dist/index.d.ts(80,31):错误TS2304:找不到名称“未知”。 node_modules/@types/pdfjs-dist/index.d.ts(82,30):错误TS2304:找不到名称“未知”。

我的package.json文件如下所示

"dependencies": {
"@angular/animations": "^6.1.10",
"@angular/common": "^6.1.0",
"@angular/compiler": "^6.1.0",
"@angular/core": "^6.1.0",
"@angular/forms": "^6.1.0",
"@angular/http": "^6.1.0",
"@angular/platform-browser": "^6.1.0",
"@angular/platform-browser-dynamic": "^6.1.0",
"@angular/router": "^6.1.0",
"@ngx-translate/core": "^11.0.1",
"@ngx-translate/http-loader": "^4.0.0",
"@vimeo/player": "^2.10.0",
"@types/node": "10.3.1",
"angular-6-datatable": "~0.8.0",
"angular-6-social-login": "~1.1.1",
"bootstrap": "^4.3.1",
"core-js": "^2.5.4",
"crypto-js": "~3.1.9-1",
"devextreme": "^19.1.5",
"devextreme-angular": "^19.1.5",
"font-awesome": "~4.7.0",
"jquery": "^3.4.1",
"ng2-drag-drop": "^3.0.2",
"ng2-pdf-viewer": "^6.0.2",
"ng5-slider": "^1.2.4",
"ngx-bootstrap": "^3.3.0",
"ngx-drag-scroll": "~7.4.2",
"ngx-image-cropper": "~1.3.10",
"ngx-loading": "^3.0.1",
"ngx-owl-carousel-o": "~1.1.5",
"ngx-rating": "0.0.9",
"ngx-slick-carousel": "^0.4.4",
"ngx-toastr": "~10.0.4",
"ngx-ui-loader": "^7.2.2",
"popper.js": "~1.15.0",
"rxjs": "~6.2.0",
"rxjs-compat": "^6.5.2",
"slick-carousel": "^1.8.1",
"stream": "0.0.2",
"swiper": "^4.5.0",
"zone.js": "~0.8.26"
},
"devDependencies": {
"@angular-devkit/build-angular": "~0.8.0",
"@angular/cli": "~6.2.9",
"@angular/compiler-cli": "^6.1.0",
"@angular/language-service": "^6.1.0",
"@types/jasmine": "~2.8.8",
"@types/jasminewd2": "~2.0.3",
"codelyzer": "~4.3.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": "~2.9.2"
}

这是我的package.json文件

2 个答案:

答案 0 :(得分:3)

我在基于Angular 6的项目中遇到了类似的问题。 来自package.json:

  "dependencies": {
    ...
    "ng2-pdf-viewer": "^5.2.3",
    "rxjs": "6.3.3",
  },
  "devDependencies": {
    ...
    "typescript": "^2.7.2"
  }

从package-lock.json(第一个由npm install命令生成):

...
"ng2-pdf-viewer": {
  "version": "5.3.4",
  "resolved": "_removed_",
  "integrity": "_removed_",
  "requires": {
    "@types/pdfjs-dist": "^2.0.1",
    "pdfjs-dist": "^2.2.228",
    "tslib": "^1.9.0"
  }
},
...
"pdfjs-dist": {
  "version": "2.2.228",
  "resolved": "_removed_",
  "integrity": "_removed_",
  "requires": {
    "node-ensure": "^0.0.0",
    "worker-loader": "^2.0.0"
  }
},
...
"@types/pdfjs-dist": {
  "version": "2.1.3",
  "resolved": "_removed_",
  "integrity": "_removed_"
},
...

为了解决该问题,我在package-lock.json文件中将@ types / pdfjs-dist版本更改为“ 2.1.0”。删除node_modules文件夹,然后执行“ npm install”。

您可能遇到的另一个问题是

ERROR in node_modules/@types/pdfjs-dist/index.d.ts(7,1): error TS1084: Invalid 'reference' directive syntax.

要解决此问题,请打开文件“ node_modules/@types/pdfjs-dist/index.d.ts”,然后在第7行附近搜索三个斜杠

/// <reference lib="dom"/>

然后将斜杠删除为“

// <reference lib="dom"/>

答案 1 :(得分:1)

您是否尝试将打字稿版本更新为3?

npm i -D typescript @ 3

“ skipLibCheck”:是