我开始的一个小项目使用一个节点模块(通过 Npm安装)声明 const
变量。运行和测试这个项目是很好的,但是在执行 UglifyJS 时,Browserify 会失败。
意外标记: 关键字(const)
这里是一个通用的 Gulp 文件,我已经成功地使用了一些其他过去的项目没有这个问题(即没有特定的节点模块)。
'use strict';
const browserify = require('browserify');
const gulp = require('gulp');
const source = require('vinyl-source-stream');
const derequire = require('gulp-derequire');
const buffer = require('vinyl-buffer');
const uglify = require('gulp-uglify');
const sourcemaps = require('gulp-sourcemaps');
const gutil = require('gulp-util');
const path = require('path');
const pkg = require('./package');
const upperCamelCase = require('uppercamelcase');
const SRC_PATH = path.dirname(pkg.main);
const DIST_PATH = path.dirname(pkg.browser);
const INPUT_FILE = path.basename(pkg.main);
const OUTPUT_FILE = path.basename(pkg.browser);
const MODULE_NAME = upperCamelCase(pkg.name);
gulp.task('default', () => {
// set up the browserify instance on a task basis
var b = browserify({
entries: INPUT_FILE,
basedir: SRC_PATH,
transform: ['babelify'],
standalone: MODULE_NAME,
debug: true
});
return b.bundle()
.pipe(source(OUTPUT_FILE))
.pipe(buffer())
.pipe(derequire())
.pipe(sourcemaps.init({loadMaps: true}))
.pipe(uglify())
.on('error', gutil.log)
.pipe(sourcemaps.write('.'))
.pipe(gulp.dest(DIST_PATH))
;
});
我已经尝试将 npm 安装的模块中的所有 const
替换为 var
,从而解决这个问题,一切都很好。所以我不明白失败的原因。
除非有人使用 IE10,否则 所有主流浏览器都支持这种语法。
有没有办法不需要更改该节点模块就可以解决这个问题?
我已经暂时(或永久)用 胡桃取代 UglifyJS,并且似乎有效。