繁体   English   中英

如何uglify javascript类?

[英]how to uglify javascript classes?

我正在使用类语法编写基本的javascript并尝试使用gulp进行uglify ,但是收到此错误:

events.js:72
扔掉 //未处理的'错误'事件

我只是使用了mozilla网站上的示例代码:

class Polygon {
  constructor(height, width) {
    this.height = height;
    this.width = width;
  }
}

我的gulp文件没什么特别的 - 适用于任何非类js:

// Include gulp
var gulp = require('gulp');

// Include Our Plugins
var jshint = require('gulp-jshint');
var concat = require('gulp-concat');
var uglify = require('gulp-uglify');
var rename = require('gulp-rename');

// Lint Task
gulp.task('lint', function() {
    return gulp.src('js/*.js')
        .pipe(jshint())
        .pipe(jshint.reporter('default'));
});

// Concatenate & Minify JS
gulp.task('scripts', function() {
    return gulp.src('js/*.js')
        .pipe(concat('all.js'))
        .pipe(gulp.dest('dist/js'))
        .pipe(rename('all.min.js'))
        .pipe(uglify())
        .pipe(gulp.dest('dist/js'));
});

// Watch Files For Changes
gulp.task('watch', function() {
    gulp.watch('js/*.js', ['lint', 'scripts']);
    gulp.watch('scss/*.scss', ['sass']);
});

// Default Task
gulp.task('default', ['lint', 'scripts', 'watch']);

当时,我通过与Babel一起转发给ECMA 5解决了这个问题。

后来我发现我的Node环境不是问题,因为评论让我相信,但实际上是因为gulp-uglify中使用的默认uglify分支还不支持ECMA 6

正确的解决方案是使用UglifyJS2harmony分支或使用npm包装器uglify-js-harmony

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM