我有一个用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”
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
}
}
答案 0 :(得分:0)
作为参考,这似乎是awesome-typescript-loader
的问题。我卸载了这个并切换到ts-loader
,这些问题就消失了。
我确认安装@types/node
,@types/jasmine
和@types/webpack-env
就足够了,而无需在webpack.conf.js或.tsconfig中进行任何额外的特殊配置。