我正在尝试使用Google Closure Compiler根据将要运行的位置(在服务器与客户端上)通过单个变量来分割我的应用程序代码。在这个例子中,将要在服务器上调用的所有内容都在isServerSide
var之后,但是,正在为客户端编译代码。所以我将isServerSide
设置为false,让编译器删除客户端不会运行的所有内容......
app.js
内部:
goog.provide('my.app');
my.app.log = function(message) {
document.write(message);
}
my.app.initClientSide = function() {
my.app.log('hello client');
}
my.app.initServerSide = function() {
my.app.log('hello server');
}
if (isServerSide) {
my.app.log('initing server');
my.app.initServerSide()
}else my.app.initClientSide();
externs.js
内部:
/**
* @define {boolean} is server side?
*/
var isServerSide=false;
命令:
java -jar bin/compiler.jar --js closure-library/closure/goog/base.js --js app.js --externs externs.js --manage_closure_dependencies true --process_closure_primitives true --summary_detail_level 3 --warning_level VERBOSE --compilation_level=ADVANCED_OPTIMIZATIONS --closure_entry_point my.app
预期产出:
document.write("hello client");
实际输出:
isServerSide?(document.write("initing server"),document.write("hello server")):document.write("hello client");
如果我在isServerSide=false;
中手动输入app.js
,那么我可以将其编译为:
isServerSide=false;document.write("hello client");
这让我觉得我设置了我的externs.js
错误(或者我只是不明白实际上应该使用什么外部实例)。
有关如何使其正常工作的任何建议吗?
答案 0 :(得分:6)
通过直接在编译器调用中设置@define值来指定它们。 Externs服务于不同的目的,如hyperslug正确陈述。
通过将@define定义(来自你的extern)放入app.js然后像这样调用编译器来实现预期的结果:
java -jar compiler.jar \
--define "isServerSide=false" \
--js closure-library/closure/goog/base.js \
--js app.js \
--manage_closure_dependencies true \
--process_closure_primitives true \
--summary_detail_level 3 \
--warning_level VERBOSE \
--compilation_level=ADVANCED_OPTIMIZATIONS \
--closure_entry_point my.app