2016-12-13 1682 views
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'] } 
}; 
+0

不應該'tslib'是依賴,不是devDependency? –

+0

是的。我剛搬了它,但問題依然存在。 – GaryB96

+0

我很遺憾現在把這個問題與webpack混淆了。我只是想普通的老'tsc',仍然可以得到 node_modules/rxjs/Subscriber.d.ts(13,36):錯誤TS2354:這句法需要進口幫手,但模塊「tslib的」無法找到。 – GaryB96

回答