我正在命令行上测试Google闭包编译器。 我采用了最新版本:
java -jar closure-compiler.jar --version
Closure Compiler (http://github.com/google/closure-compiler)
Version: v20190618
Built on: 2019-06-21 17:24
我正在生成这样的javascript压缩版本:
java -jar closure-compiler.jar my_script.js > out.js
问题是生成的代码大于我在https://closure-compiler.appspot.com/home使用在线服务时得到的代码
我注意到命令行版本在开始时添加了以下代码:
var $jscomp=$jscomp||{};$jscomp.scope={};$jscomp.findInternal=function(a,c,b){a instanceof String&&(a=String(a));for(var d=a.length,e=0;e<d;e++){var f=a[e];if(c.call(b,f,e,a))return{i:e,v:f}}return{i:-1,v:void 0}};$jscomp.ASSUME_ES5=!1;$jscomp.ASSUME_NO_NATIVE_MAP=!1;$jscomp.ASSUME_NO_NATIVE_SET=!1;$jscomp.SIMPLE_FROUND_POLYFILL=!1;
$jscomp.defineProperty=$jscomp.ASSUME_ES5||"function"==typeof Object.defineProperties?Object.defineProperty:function(a,c,b){a!=Array.prototype&&a!=Object.prototype&&(a[c]=b.value)};$jscomp.getGlobal=function(a){return"undefined"!=typeof window&&window===a?a:"undefined"!=typeof global&&null!=global?global:a};$jscomp.global=$jscomp.getGlobal(this);
$jscomp.polyfill=function(a,c,b,d){if(c){b=$jscomp.global;a=a.split(".");for(d=0;d<a.length-1;d++){var e=a[d];e in b||(b[e]={});b=b[e]}a=a[a.length-1];d=b[a];c=c(d);c!=d&&null!=c&&$jscomp.defineProperty(b,a,{configurable:!0,writable:!0,value:c})}};$jscomp.polyfill("Array.prototype.find",function(a){return a?a:function(a,b){return $jscomp.findInternal(this,a,b).v}},"es6","es3");
我的脚本中没有这样的代码:它来自哪里? 如何产生与在线版本相同的输出?
答案 0 :(得分:0)
这可能是Web服务上的设置与您在本地使用的设置之间的差异。
看看Closure Compiler: Flags and Options,了解您可能喜欢的设置。
如果您要共享资源,则可以尝试帮助您缩小选择范围。
对于额外的代码,我认为它至少部分是Array.prototype.find
(又名[].find
)的polyfill,我假设您的代码中是?>
如果是这样,那就是Closure注入代码,以改善您的跨浏览器兼容性。
答案 1 :(得分:0)
要使编译器命令行作为Web服务工作,我只添加了一个选项:
--language_out=ECMASCRIPT_2015