[英]How do I use Google Closure Stylesheet renaming with an external Javascript Library such as jQuery?
我正在研究Google的样式表重命名功能,我不知道如何重写我的jquery选择器。 我没有发现该文件非常明确。
如果我有一些看起来像这样的代码:
<div class="MyClass"></div>
<div id="MyID"></div>
$('.MyClass').someFunc();
$('#MyID').someFunc();
如何编写HTML和javascript以便CSS重命名可以工作?
谢谢你的建议。
要使Closure-stylesheets与jQuery等外部库结合使用,您还需要使用Closure-library来添加对goog.getCssName
支持。 但是,因为编写Closure-Library是为了最大限度地利用Closure-compiler的死代码消除,所以最终输出中只包含非常少量的库代码(在本例中约为1KB)。
您需要以下工具:
@def BG_COLOR rgb(235, 239, 249);
@def DIALOG_BORDER_COLOR rgb(107, 144, 218);
@def DIALOG_BG_COLOR BG_COLOR;
.MyClass {
background-color: BG_COLOR;
height:100px;
}
#MyId {
background-color: DIALOG_BG_COLOR;
border: 1px solid DIALOG_BORDER_COLOR;
height:100px;
}
{namespace ClosureSample}
/**
* SampleHtml
*/
{template .SampleHtml autoescape="false"}
<div class="{css MyClass}"></div>
{/template}
goog.require('ClosureSample');
document.write(ClosureSample.SampleHtml());
$(function() {
$('.' + goog.getCssName('MyClass')).css('background-color', 'pink');
});
<!DOCTYPE html>
<html>
<head>
<title>Closure stylesheets with External Library</title>
<link rel="Stylesheet" media="all" href="sample.css" />
<script type="text/javascript" src="sample_renaming_map.js"></script>
<script type="text/javascript" src="http://closure-library.googlecode.com/svn/trunk/closure/goog/base.js"></script>
<script type="text/javascript">
goog.require('goog.soy');
goog.require('goog.string.StringBuffer');
</script>
<script type="text/javascript" src="soyutils_usegoog.js"></script>
<script type="text/javascript" src="sample-templates.js"></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
</head>
<body>
<script type="text/javascript" src="sample.js"></script>
<div id="MyId"></div>
</body>
</html>
使用来自模板和样式表的项目下载的工具,你需要编译sample.gss
和sample.soy
文件。 以下是此示例使用的命令:
java -jar closure-stylesheets.jar \
--pretty-print \
--output-file sample.css \
--output-renaming-map-format CLOSURE_UNCOMPILED \
--rename CLOSURE \
--output-renaming-map sample_renaming_map.js \
sample.gss
java -jar SoyToJsSrcCompiler.jar \
--shouldProvideRequireSoyNamespaces \
--shouldGenerateJsdoc \
--outputPathFormat {INPUT_FILE_NAME_NO_EXT}.js \
--cssHandlingScheme goog \
sample.soy
使用这些文件,您可以在开发期间测试重命名。 查看示例 。
首先使用“CLOSURE_COMPILED”选项重新编译样式表以生成重命名映射:
java -jar closure-stylesheets.jar \
--output-file sample.css \
--output-renaming-map-format CLOSURE_COMPILED \
--rename CLOSURE \
--output-renaming-map sample_renaming_map.js \
sample.gss
然后,您将需要计算Closure库依赖文件并将所有源JavaScript文件编译为单个源。
Closure-library项目中的calcdeps.py脚本也可用于在它确定的输入文件上调用Closure-compiler。
python calcdeps.py \
-i sample.js \
-p PATH_TO_CLOSURE_LIBRARY_FOLDER \
-p sample-templates.js \
-o compiled \
-c compiler.jar \
-f --js=sample_renaming_map.js
-f --compilation_level=ADVANCED_OPTIMIZATIONS \
-f --warning_level=VERBOSE \
-f --externs=jquery-1.7-externs.js \
-f --js_output_file=sample_compiled.js
查看最终结果: 编译版本 。
正如您所看到的,使用Google Closure Stylesheets不仅需要整个Closure-tools套件的一部分,而且还需要参与其中。
document.write
调用来输出正确重命名的类的HTML,但是生产代码有更优雅和可维护的技术。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.