0

我有如下代码:

define('identity', function () {
    // LOT OF CONSTANTS AND USAGE HAS BEEN REMOVED FOR BREVITY
    'use strict';
    var CREATE_ACCOUNT = 'CreateAccount';
    var ACCOUNT = 'Account';
    var CONNECT = 'Connect';
    var SWITCH = 'Switch';
    var FB = 'FB';
    var PIPE_SEPARATOR = ' | ';
    var DOT_SEPARATOR = '.';
    var COMMA_SEPARATOR = ', ';

    function concatenateWithDotSeparater(array) {
        return concatenateWithSeparator(array,DOT_SEPARATOR);
    }

    function concatenateWithPipeSeparater(array) {
        return concatenateWithSeparator(array,PIPE_SEPARATOR);
    }

    function concatenateWithCommaSeparater(array) {
        return concatenateWithSeparator(array, COMMA_SEPARATOR);
    }

    function concatenateWithSeparator(array, separator) {
        return array.join(separator);
    }

    return {
        signUp: {
            facebookConnect : concatenateWithDotSeparater([CREATE_ACCOUNT, FB, CONNECT]),
            }
    };
}); 

本质上,我有很多重复的常量,需要连接起来才能产生实际值。因此,我创建了常量来保存重复值,然后通过函数将它们连接起来。

但是当我尝试使用 gulp-minify 版本 1.0.0 缩小 JS 时,结果如下: return{signUp:{facebookConnect:e(["CreateAccount","FB","Connect"])}}

它注入了实际值。我怎样才能防止这种情况?

我喜欢得到这样的输出:return{signUp:{facebookConnect:e([s,d,e])}}

我正在使用缩小,例如:

.pipe(minify({
    ext: {
        src: '.js',
        min: '-min.js'
    }
}))

请帮忙。

4

1 回答 1

0

如果您在应该设置要保存不变的名称列表的位置设置选项 mangle,则可以避免重命名某些变量。在引擎盖下,gulp-minify数据包使用uglify-es数据包。查看它以获取详细的文档。

请尝试以下选项:

.pipe(minify({
    ext: {
        src: '.js',
        min: '-min.js'
    },
    mangle: { reserved: ['CREATE_ACCOUNT', 'ACCOUNT', 'CONNECT'] // etc
}))
于 2017-06-29T15:28:42.483 回答