如何防止`gulp-uglify`移动我的全局变量?

时间:2017-06-01 22:18:17

标签: javascript node.js gulp gulp-uglify

我正在使用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'));

});

1 个答案:

答案 0 :(得分:1)

hoist_funs选项设置为false

.pipe(uglify({
    compress: {
        hoist_funs: false
    }
})