如何丑化 javascript 类?
how to uglify javascript classes?
我正在使用 classes syntax and trying to uglify it with gulp 编写基本 javascript,但收到此错误:
events.js:72
throw er; // Unhandled 'error' event
我只是使用了 mozilla 网站上的示例代码:
class Polygon {
constructor(height, width) {
this.height = height;
this.width = width;
}
}
我的 gulp 文件没有什么特别之处 - 适用于任何非 class 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']);
当时,我通过 transpiling to ECMA 5 with Babel 的解决方法解决了这个问题。
后来我发现这不是我的 Node 环境的问题,正如评论让我相信的那样,但实际上是因为 the default uglify branch used in gulp-uglify doesn't support ECMA 6 yet.
正确的解决方案是使用 harmony
branch of UglifyJS2 or to use the npm wrapper uglify-js-harmony。
我正在使用 classes syntax and trying to uglify it with gulp 编写基本 javascript,但收到此错误:
events.js:72
throw er; // Unhandled 'error' event
我只是使用了 mozilla 网站上的示例代码:
class Polygon {
constructor(height, width) {
this.height = height;
this.width = width;
}
}
我的 gulp 文件没有什么特别之处 - 适用于任何非 class 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']);
当时,我通过 transpiling to ECMA 5 with Babel 的解决方法解决了这个问题。
后来我发现这不是我的 Node 环境的问题,正如评论让我相信的那样,但实际上是因为 the default uglify branch used in gulp-uglify doesn't support ECMA 6 yet.
正确的解决方案是使用 harmony
branch of UglifyJS2 or to use the npm wrapper uglify-js-harmony。