2

我在 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 文件

4

2 回答 2

7

我的基于 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"/>
于 2020-01-09T09:22:33.733 回答
1

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

npm i -D typescript@3

或者

“skipLibCheck”:真

于 2020-01-07T08:38:48.530 回答