Webpack 在编译 TypeScript 代码失败时导致 gulp watch 崩溃

2023-12-30

我正在运行一个 gulp-watch 任务,它正在编译我的前端应用程序。当我遇到打字稿错误时(只是因为我太早点击保存),整个过程崩溃,我必须手动重新启动它。我希望 webpack 和 typescript 编译器只报告错误,只要它们在监视模式下运行,而不是使进程崩溃。

我的 gulp 任务是使用 webpack 编译我的 typescript 应用程序:

gulp.task('scripts', function (callback) {
    var isWatching = watchEnabled;

    var webpackOptions = {
        resolve: { extensions: ['', '.ts'] },
        watch: watchEnabled,
        module: {
            preLoaders: [{ test: /\.ts$/, exclude: /node_modules/, loader: 'tslint-loader' }],
            loaders: [{ test: /\.ts$/, exclude: /node_modules/, loader: 'awesome-typescript-loader' }]
        },
        output: { filename: 'app.js' },
        tslint: { emitErrors: !watchEnabled } // tslint crashes gulp when emitting errors, so don't do it while watch is enabled
    };

    if (debugEnabled) {
        webpackOptions.devtool = 'inline-source-map';
    }

    var webpackChangeHandler = function (err, stats) {
        if (err) {
            console.error('Webpack', err);
        }
        $.util.log(stats.toString({
            colors: $.util.colors.supportsColor,
            chunks: false,
            hash: false,
            version: false
        }));

        if (isWatching) {
            isWatching = false;
            callback();
        }
    };

    return gulp.src('./Scripts/application/app.ts')
      .pipe(webpack(webpackOptions, null, webpackChangeHandler))
      .pipe($.if(!debugEnabled, $.uglify()))
      .pipe($.if(!watchEnabled, $.rev()))
      .pipe(gulp.dest(tmpFolder + 'Content/'));
});

在 CI 服务器中进行编译时,最好编译和 tslint 错误会导致进程崩溃,并且 CI 服务器会报告错误。

但是开发的时候却很烦人。我已经解决了 tslint 问题,只要 gulp watch 和 webpack watch 正在运行,就关闭 emitErrors 。但对于打字稿编译我不知道该怎么做。

我应该在 webpack 或 Awesome-typescript-loader 上找到这个选项吗?

我在 Awesome-typescript-loader github 存储库上没有找到任何适合这个问题的内容,这让我觉得我应该启用一些 webpack 选项,但是哪个呢?


有同样的问题。这对我有用

var wp = webpack(webpackOptions, null, webpackChangeHandler);
// can bind error to console, but it will be duplicated with webpackChangeHandler err
// wp.on('error', console.error.bind(console));
wp.on('error', function() {});

return gulp.src('./Scripts/application/app.ts')
      .pipe(wp)
      .pipe($.if(!debugEnabled, $.uglify()))
      .pipe($.if(!watchEnabled, $.rev()))
      .pipe(gulp.dest(tmpFolder + 'Content/'));
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Webpack 在编译 TypeScript 代码失败时导致 gulp watch 崩溃 的相关文章

随机推荐