0
我得到錯誤TS2354:這句法需要進口幫手,但模塊「tslib的」無法找到。在我的webpack 2版本中使用TypeScript 2.1的新importHelpers
選項。 該包似乎按預期構建,但錯誤消息令人不安。 任何人都可以指出我在這裏做錯了嗎?或者是與rxjs\Subject.d.ts
%的誤差問題(即提到行(Subject.d.ts:9,43)不使用和無辜extends
關鍵字)?如何在TypeScript 2.1.4中消除TS2354錯誤消息?
ts-loader: Using [email protected] and C:Repro\stuff\tsconfig.json
Hash: f24da06626836e4fc997
Version: webpack 2.1.0-beta.28
Time: 4256ms
Asset Size Chunks Chunk Names
app.js 3.01 kB 0 [emitted] app
[1] ./src/main.ts 372 bytes {0} [built]
+ 1 hidden modules
ERROR in C:Repro\stuff\node_modules\rxjs\Subject.d.ts
(9,43): error TS2354: This syntax requires an imported helper but module 'tslib' cannot be found.
main.ts
import { Observable } from "rxjs";
Observable.timer(3000, 5000)
.timeInterval()
.subscribe((interval) => console.log(interval));
的package.json
{
"name": "stuff",
"version": "1.0.0",
"scripts": {
"build": "webpack"
},
"devDependencies": {
"@types/core-js": "^0.9.35",
"ts-loader": "^1.3.2",
"typescript": "^2.1.4",
"webpack": "^2.1.0-beta.25"
},
"dependencies": {
"rxjs": "^5.0.1",
"tslib": "^1.2.0"
}
}
tsconfig.json
{
"compilerOptions": {
"module": "commonjs",
"importHelpers": true,
"target": "es5",
"noEmitHelpers": true
}
}
webpack.config.js
module.exports = {
name: 'server',
target: 'node',
entry: { 'app': './src/main.ts' },
output: { path: './bin/', publicPath: 'bin/', filename: '[name].js' },
externals: { rxjs: 'commonjs rxjs' },
module: { rules: [{ test: /\.ts$/, loader: 'ts-loader' }], },
resolve: { extensions: ['.ts'] }
};
不應該'tslib'是依賴,不是devDependency? –
是的。我剛搬了它,但問題依然存在。 – GaryB96
我很遺憾現在把這個問題與webpack混淆了。我只是想普通的老'tsc',仍然可以得到 node_modules/rxjs/Subscriber.d.ts(13,36):錯誤TS2354:這句法需要進口幫手,但模塊「tslib的」無法找到。 – GaryB96