Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Crox is a high performance cross-language template engine, written by the JavaScript.
github的 markdown 无法很好的表达我对 Crox
的深情厚意。
如果您也想了解Crox所做的事情,强烈欢迎您到 Crox的thx官网 上看看~
Crox是一个由JavaScript语言实现的高性能跨语言模板引擎。
Crox模板可以直接在JavaScript环境中使用,也可以翻译成PHP、JSP等其他编程语言的可执行方法,或翻译成Velocity、Smarty等其他模板引擎的源模板。
Crox将保证翻译后的结果具备最佳执行效率。
{{root}}
// 输出 data
{{root.name}}
// 输出 data.name
{{root.value * 2}}
// 输出 2 倍的 data.value
Crox模板支持多种运算符:.
[]
!
*
/
%
+
-
<
>
<=
>=
===
!==
{{#if root.ok}}
好,又赢了 {{/if}}
{{#if root.length > 0}}
有 {{else}}
没了 {{/if}}
each用于循环数组或对象
{{#each root 'val'}}
{{val}}
{{/each}}
{{#each root 'val' 'key'}}
{{key}}
=> {{val}}
{{/each}}
重复使用的较长的表达式,可以赋值给一个变量,例如:
{{set a = data.lilei.mother.phone.brand}}
如果 data.lilei.mother.phone.brand
对应的数据下还有其他属性(例如:prop
),则可以通过 a
获取到:
prop属性的值为 {{a.prop}}
// 获取到 data.lilei.mother.phone.brand.prop的属性值
{{include "path/to/file.tpl"}}
// 导入file.tpl
更多语法说明请参见: http://thx.github.io/crox/apis/tpl-api/
Crox的所有接口都声明在 Crox
这个JS对象上的。目前,具体的接口包括:
Crox.parse:解析Crox模板生成语法树AST
Crox.render:将数据填充到Crox模板中,并生成渲染后的结果
Crox.compile:将Crox模板编译成 原生JS Function
Crox.compileToPhp:将Crox模板编译成 PHP函数
Crox.compileToVM:将Crox模板翻译成 Velocity模板
更多API说明请参见 http://thx.github.io/crox/apis/js-api/
<!-- 加载 Crox -->
<script src="http://g.tbcdn.cn/thx/crox/1.1.0/crox-all.js"></script>
var tmpl = '{{root.a}} - {{root.b}}';
// 编译成原生js Function
var fn = Crox.compile(tmpl);
var html = fn({
a: 1,
b: 2
});
console.log(html); // 1 - 2
目前Crox已经加入 Kissy Gallary ,通过以下方式即可使用Crox。
KISSY.config({
packages:[
{
name: "gallery",
path: "http://a.tbcdn.cn/s/kissy/",
charset: "utf-8"
}
]
});
KISSY.use('gallery/crox/1.0/index', function (S, Crox) {
var tmpl = '{{root.a}} - {{root.b}}';
// 编译成原生js Function
var fn = Crox.compile(tmpl);
var html = fn({
a: 1,
b: 2
});
console.log(html); // 1 - 2
})
// 配置 Crox 路径
seajs.config({
alias:{
'crox':'http://g.tbcdn.cn/thx/crox/1.1.0/seajs/crox.js'
}
})
// 加载 Crox
seajs.use('crox', function(Crox){
var tmpl = '{{root.a}} - {{root.b}}';
// 编译成原生js Function
var fn = Crox.compile(tmpl);
var html = fn({
a: 1,
b: 2
});
console.log(html); // 1 - 2
})
// 配置 Crox 路径
require.config({
paths:{
'crox':'http://g.tbcdn.cn/thx/crox/1.1.0/amd/crox'
}
})
// 加载 Crox
require(['crox'], function(Crox){
var tmpl = '{{root.a}} - {{root.b}}';
// 编译成原生js Function
var fn = Crox.compile(tmpl);
var html = fn({
a: 1,
b: 2
});
console.log(html); // 1 - 2
})
Crox已经加入npmjs,Crox本身是一个nodejs模块,可被其他模块引用。
另外,Crox也提供命令行工具,可以很方便的将Crox模板转化成js文件或php文件。
如果想引用Crox模块,可以用 npm install crox
命令,将Crox安装到nodejs中。
如果同时想使用命令行工具,可以用 npm install -g crox
(可能需要sudo) 命令,安装Crox模块,并生成Crox命令行工具。
Crox API列出的所有功能,在 Nodejs版本 中同样可用。
使用时,将 crox
模块 通过 require
引入即可使用。
// 请先确保通过 npm install 已安装
var Crox = require('crox');
var tmpl = '{{set ok = root.ok}} {{#if ok}} 好 {{else}} 不好 {{/if}}';
// 将模板翻译成php
var php = Crox.compileToPhp(tmpl);
console.log(php);
用node运行这段JS,控制台输出是一段 php
代码,内容如下:
function temp($i_root) {
// 为了篇幅,这里忽略一部分辅助方法 :-)
$t_r = '';
$i_ok = $i_root->ok;
$t_r .= ' ';
if($i_ok){
$t_r .= ' 好 ';
}
else{
$t_r .= ' 不好 ';
}
$t_r .= '
';
return $t_r;
}
请先确保已通过 npm install -g crox
安装了crox命令行工具
命令行工具目前包含以下几个参数:
-p
| --package-path
设置待翻译Crox模板的根路径,默认是 当前路径
-e
| --encoding
设置Crox模板文件的编码方式,默认是 utf-8
--target-type
翻译成的目标语言,比如:php|js等,默认是 js
--tpl-suffix
模板文件后缀,默认是 tpl
-o
| --output
翻译后文件的目标文件夹,默认是 当前路径
假设:当前路径下的 a.tpl
文件中包含如下内容:
{{set ok = root.ok}} {{#if ok}} 好 {{else}} 不好 {{/if}
在当前路径下,运行 crox --target-type js
,Crox会将 a.tpl
文件内容翻译成js Function,生成 a.js
文件,内容如下:
function anonymous(root) {
// 为了篇幅,这里忽略一部分辅助方法 :-)
var $s = '';function $print(s){ $s += s; } var ok=root.ok;
$print(" ");
if(ok){
$print(" 好 ");
}
else{
$print(" 不好 ");
}
return $s;
}
同理,运行 crox --target-type php
,将会翻译 a.tpl
并生成php文件 a.php
。
Crox是跨语言的模板引擎。
Crox支持子模板导入(include),一个模板可能include多个子模板,而每一个子模板,又可能include其他子模板。
以Kissy为基础的前端环境中,模板之间的依赖关系,非常像Kissy模块之间的依赖关系。Kissy所支持的模块依赖机制,能够与Crox的include进行良好的对应。
因此,为了更好的完成Crox到Kissy模块的翻译,将Crox include机制和Kissy模块加载机制对应起来,并保证发布后的Crox-Kissy模块的效率,我们开发了一个Kissy下使用Crox的辅助工具。
此工具在不同的使用场景时所做的具体工作如下:
开发时,Crox模板tpl被编译成一个Kissy模块,该模块保留原模板内容,并依赖Crox和其他子模板。Demo
发布时,Crox模板tpl被Crox.compile翻译成原生js Function,并被包装成Kissy模块(所有子模板依赖都将被替换)。该模块不依赖Crox,也不依赖子模块。 Demo
src/app/partials/header/index.tpl
<div class="header">
<h2><span>logo</span> {{include ./user/index.tpl}} </h2>
</div>
src/app/partials/header/user/index.tpl
<div class="user">
用户:<a href="#nogo">{{root.username}}</a>
</div>
src/app/partials/header/index.tpl.js
KISSY.add('app/partials/header/index.tpl', function(S, Crox, $1) {
var tmpl =
'<div class="header">\
<h2><span>logo</span> {{include ./user/index.tpl}} </h2>\
</div>';
tmpl = tmpl.replace(RegExp('{{include ./user/index.tpl}}', 'g'), $1.tmpl);
return {
tmpl: tmpl,
fn: Crox.compile(tmpl)
}
}, {
requires: [
'crox', './user/index.tpl'
]
});
src/app/partials/header/user/index.tpl.js
KISSY.add('app/partials/header/user/index.tpl', function(S, Crox) {
var tmpl =
'<div class="user">\
用户:<a href="#nogo">{{root.username}}</a>\
</div>';
return {
tmpl: tmpl,
fn: Crox.compile(tmpl)
}
}, {
requires: [
'crox'
]
});
build/app/partials/header/index.tpl.js
KISSY.add('app/partials/header/index.tpl', function(S) {
var croxFn = function anonymous(root) {
// 为了篇幅,这里忽略一部分辅助方法 :-)
var $s = '';function $print(s){ $s += s; } $print("<div class=\"header\"> <h2><span>logo</span> <div class=\"user\"> 用户:<a href=\"#nogo\">");
$print($htmlEncode(root.username));
$print("</a></div> </h2></div>");
return $s;
};
return {
fn: croxFn
};
});
build/app/partials/header/user/index.tpl.js
KISSY.add('app/partials/header/user/index.tpl', function(S) {
var croxFn = function anonymous(root) {
// 为了篇幅,这里忽略一部分辅助方法 :-)
var $s = '';function $print(s){ $s += s; } $print("<div class=\"user\"> 用户:<a href=\"#nogo\">");
$print($htmlEncode(root.username));
$print("</a></div>");
return $s;
};
return {
fn: croxFn
};
});
更多介绍,请移步:http://gitlab.alibaba-inc.com/thx/crox-kissy.
Crox试用旺旺群:891026490
,欢迎进群或提Issue反馈意见
FAQs
Crox is a high performance cross-language template engine, written by the JavaScript.
We found that crox demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 5 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.