无法使用uglify-js删除console.log语句

Can uglify-js remove the console.log statements?

本文关键字:console log 语句 删除 uglify-js      更新时间:2023-09-26

我正在使用uglify js来缩小源代码。我想删除原始源代码的console.log语句。有可能吗?或者有其他压缩机工具支持这一点吗?

我在Node.js.中使用如下代码

var uglify = require('uglify-js');
var originalSourceCode = 'var name = function(){var str = "test"; return str}; console.log("log data");';
var minifiedCode = uglify.minify(originalSourceCode, {
                fromString : true,
                mangle: {},
                warnings: true
            });
console.log(minifiedCode);

输出为:

$node m.js
{ code: 'var name=function(){var a="test";return a};console.log("log data");',
  map: 'null' }

在缩小的代码中,console.log没有被删除。

最近(2013年末)添加了另一个名为drop_console的选项

drop_console -- default false. Pass true to discard calls to console.* functions

这被添加到grunt init配置中,如下所示:

grunt.initConfig({
  uglify: {
    options: {
      compress: {
        drop_console: true // <-
      }
    },
    my_target: {
      files: {
        'dest/output.min.js': ['src/input.js']
      }
    }
  }
});

从grunt contrib uglify github文档中获取

在最新的uglify js(v2.4.3)中,添加了一个新的压缩选项"pure_funcs"。如果我将console.log函数添加到这个数组中,它将在缩小的js文件中被删除。下面的测试代码显示了此选项的工作方式。这正是我想要的。

// file: m.js
var uglify = require('uglify-js');
var originalSourceCode = 'var name = function(){var str = "test"; return str}; console.log("log data" + name());';
var minifiedCode = uglify.minify(originalSourceCode, {
                fromString : true,
                mangle: {},
                warnings: true,
                compress:{
                    pure_funcs: [ 'console.log' ]
                }
            });
console.log(minifiedCode);
$node m.js
WARN: Dropping side-effect-free statement [?:1,53]
{ code: 'var name=function(){var n="test";return n};',
  map: 'null' }

报价来自https://github.com/mishoo/UglifyJS2

pure_funcs——默认为null。您可以传递一个名称数组,UglifyJS将假设这些函数不会产生副作用。危险:不会检查名称是否在作用域中重新定义。一个例子例如var q=Math.floor(a/b)。如果变量q不是在其他地方使用时,UglifyJS将删除它,但仍将保留数学。floor(a/b),不知道它做什么。您可以传递pure_funcs:['Math.floor'],让它知道这个函数不会产生任何副作用,在这种情况下,整个语句将被丢弃。当前的实现增加了一些开销(压缩较慢)。

对于-c选项,将drop_console设置为true uglifyjs app.js -m -c drop_console=true -o app.min.js

您可以使用Groundskeeper来完成此操作,尽管这将是一个单独的步骤。

如果您正在使用gump,请使用'gulp-stape-debug'删除控制台、警报和调试器。https://www.npmjs.com/package/gulp-strip-debug