我正在使用gulp-uglify和我的gulp设置来模仿生产环境的js代码。
我有这样的代码
var test = 1;
function getTest(myTest)
{
if(!myTest) {
return test;
}
return myTest;
}
然而,当我运行gulp时,输出变为(为了便于阅读,我保持清洁)
function getTest(myTest)
{
if(!myTest) {
return test;
}
return myTest;
}
var test = 1;
如何阻止gulp-uglify
更改顺序或全局变量。
我首先连接我的文件,然后uglify。
我尝试将以下对象传递给uglify
,但它仍在改变顺序。
uglify({ mangle: false })
uglify({ mangle: { reserved: ['test'] } })
以下是依赖项列表
"license": "ISC",
"devDependencies": {
"gulp": "^3.9.1",
"gulp-autoprefixer": "^3.1.1",
"gulp-concat": "^2.6.0",
"gulp-debug": "^2.1.2",
"gulp-ignore": "^2.0.1",
"gulp-minify-css": "^1.2.4",
"gulp-sass": "^2.3.2",
"gulp-sourcemaps": "^1.6.0",
"gulp-uglify": "^2.0.0",
"gulp-util": "^3.0.7"
}
这是我的gulp任务
gulp.task('compileJs', function () {
gulp.src(jsFiles['final'])
.pipe(sourcemaps.init())
//only uglify if gulp is ran with '--type production'
.pipe(isProduction() ? uglify() : gutil.noop())
.pipe(concat('final.js'))
.pipe(sourcemaps.write())
.pipe(gulp.dest('./Public/Js'));
});
答案 0 :(得分:1)
将hoist_funs
选项设置为false
。
.pipe(uglify({
compress: {
hoist_funs: false
}
})