2016-12-13 1688 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

回答