@types无法在Angular 4 TypeScript应用程序

时间:2017-06-14 09:32:19

标签: angular typescript jasmine typescript-typings

我有一个用TypeScript编写的小型Angular 4应用程序,它也使用Webpack和Jasmine测试框架。

我已为Jasmine和Node安装了@types包,例如:@types/jasmine@types/node,并且可以在node_modules文件夹中看到它们。

但是,当我构建应用程序时,我在命令行窗口中看到错误,例如:

  

[at-loader]中的错误./app/welcome/app.welcome.spec.ts:4:1       TS2304:找不到名称'describe'。

应用程序本身似乎仍然有用,只是看到这些错误很烦人。

我的package.json文件如下:

{
    "name": "ng4-ts-demo",
    "version": "1.0.0",
    "description": "An Angular4 with TypeScript demo",
    "main": "main.ts",
    "scripts": {
        "test": "karma start",
        "build": "webpack --config webpack.config.js"
     },
     "author": "Dan",
     "license": "MIT",
     "devDependencies": {
         "@types/jasmine": "^2.5.52",
         "@types/node": "^7.0.31",
         "angular2-template-loader": "^0.6.2",
         "awesome-typescript-loader": "^3.1.3",
         "clean-webpack-plugin": "^0.1.16",
         "css-loader": "^0.28.1",
         "html-loader": "^0.4.5",
         "html-webpack-plugin": "^2.28.0",
         "jasmine-core": "^2.6.1",
         "karma": "^1.6.0",
         "karma-chrome-launcher": "^2.1.0",
         "karma-coverage": "^1.1.1",
         "karma-jasmine": "^1.1.0",
         "karma-sourcemap-loader": "^0.3.7",
         "karma-webpack": "^2.0.3",
         "node-sass": "^4.5.2",
         "sass-loader": "^6.0.3",
         "style-loader": "^0.17.0",
         "typescript": "^2.3.4",
         "webpack": "^2.4.1"
     },
     "dependencies": {
         "@angular/cli": "^1.0.2",
         "@angular/common": "^4.1.0",
         "@angular/compiler": "^4.1.0",
         "@angular/core": "^4.1.0",
         "@angular/platform-browser": "^4.1.0",
         "@angular/platform-browser-dynamic": "^4.1.0",
         "core-js": "^2.4.1",
         "moment": "^2.18.1",
         "reflect-metadata": "^0.1.10",
         "rxjs": "^5.3.1",
         "zone.js": "^0.8.9"
     }
}

修改

我通过在test-main.ts文件中导入types模块修复了Jasmine问题:

import '@types/jasmine';

但是,在main.ts文件中导入节点类型无法解决问题。它确实消除了错误,例如:

  

[at-loader]中的错误./test-main.ts:16:18       TS2304:找不到名称'require'。

但我看到了错误:

  

./main.ts中的错误   找不到模块:错误:无法解析'@ types / node'

在浏览器的控制台中,我看到了类似的消息

  

未捕获错误:找不到模块“@ types / node”

编辑2

Jasmine错误只在进行常规构建时才会修复。当实际运行测试时(使用Karma),我看到:

  

找不到模块:错误:无法解析'@ types / jasmine'

我一直在使用official Angular/Webpack docs,这并没有提到这些错误,也没有在任何地方导入@types,而且从我到处看到的@types应该一旦安装就可以工作..?

.tsconfig文件位于项目的根目录(与node_modules相同的级别),如下所示:

{
    "compilerOptions": {
        "target": "es5",
        "module": "commonjs",
        "moduleResolution": "node",
        "sourceMap": true,
        "emitDecoratorMetadata": true,
        "experimentalDecorators": true,
        "lib": [ "es2015", "dom" ],
        "noImplicitAny": true,
        "suppressImplicitAnyIndexErrors": true
    }
}

1 个答案:

答案 0 :(得分:0)

作为参考,这似乎是awesome-typescript-loader的问题。我卸载了这个并切换到ts-loader,这些问题就消失了。

我确认安装@types/node@types/jasmine@types/webpack-env就足够了,而无需在webpack.conf.js或.tsconfig中进行任何额外的特殊配置。