TypeScript 2.1.4 ломает изменения в webpack ts-loader
Обновление с Typescript 2.0.10 до 2.1.4, по-видимому, нарушает что-либо в webpack, webpack-stream, ts-loader или gulp, так как оно больше не соответствует моей точке входа или глобалу gulp source. Похоже, что он включает в себя все файлы.ts в моем проекте (включая файлы в исходной папке /server), а не только файлы ts в /client и app.ts согласно точке входа gulp.src и web pack. Есть ли другой / более новый / лучший способ, которым я должен делать это?
в файле глотка:
const serverPath = 'server';
const clientPath = 'client';
const buildPath = 'build';
const paths = {
server: {
scripts: [
`${serverPath}/**/*.ts`
]
},
client: {
files: [
`${clientPath}/**/*`
],
scripts: [
`${clientPath}/**/*.ts`
],
entry: `${clientPath}/app.ts`
}
};
gulp.task('build:client', cb => {
gulp.src(paths.client.entry)
.pipe(webpackStream(webpackConfig, webpack))
.pipe(gulp.dest(`${buildPath}/${clientPath}`));
cb();
});
в конфигурации веб-пакета:
entry: {
app: './client/app.ts'
}
ts: {
configFileName: './tsconfig.json'
}
resolve: {
extensions: ['', '.webpack.js', '.web.js', '.ts', '.tsx', '.js']
}
module: {
loaders: [
{ test: /\.ts$/, loader: 'ng-annotate-loader!ts-loader' }
]
}
в tsconfig.json:
{
"compilerOptions": {
"module": "commonjs",
"target": "es6",
"removeComments": false,
"noImplicitAny": true,
"sourceMap": true,
"inlineSources": true,
"experimentalDecorators": true,
"emitDecoratorMetadata": true
}
}
Вывод с использованием 2.0.10:
ts-loader: Using typescript@2.0.10 and /Users/chris/code/class-app/tsconfig.json
[20:47:36] Version: webpack 1.14.0
Asset Size Chunks Chunk Names
app.js.map 950 bytes 0 [emitted] app
app.js 550 bytes 0 [emitted] app
Вывод с использованием 2.1.4:
ts-loader: Using typescript@2.1.4 and /Users/chris/code/class-app/tsconfig.json
server/api/thing/thing.controller.ts(17,16): error TS2322: <ts error in server portion, not relevant>
[20:53:03] TypeScript: 1 semantic error
[20:53:03] TypeScript: emit succeeded (with errors)
Unhandled rejection Error in plugin 'webpack-stream'
Message:
/Users/chris/code/class-app/server/api/thing/thing.controller.ts <same as above>
1 ответ
Очевидно, проблема в том, что TypeScript в WebPack все это время выполнялся на серверном коде (хотя этого не должно было быть), и хотя я планировал исправить проблему с TS сервера, возникшую при обновлении TypeScript, на самом деле он обнаружил компиляцию WebPack. файлы, которые он не должен иметь все время. Протестировал это, преднамеренно представив проблему серверу ts в предыдущей ("рабочей") версии TypeScript, получив ту же ошибку.
Мне все еще нужно выяснить, почему он пытается скомпилировать все мои файлы TS, а не только те, которые находятся в / client, но я задам новый вопрос для этого.