Web 模板引擎是为了使用户界面与业务数据(内容)分离而产生的,它可以生成特定格式的文档,通常是标准的 HTML 文档。当然不同的开发语言有不同模板引擎,如 Javascript 下的 Hogan 、ASP 下的 aspTemplate、以及 PHP 下的 Smarty,这里主要介绍基于 Javascript 语言的模板引擎,目前流行有 Mustache、Hogan、doT.js、JsRender、Kendo UI Templates等,jsperf.com上可以看到它们的性能对比,首先先介绍下 Mustache。
一、Mustache 简介:
Mustache 是一个 logic-less (轻逻辑)模板解析引擎,它的优势在于可以应用在 Javascript、PHP、Python、Perl 等多种编程语言中。
二、Mustache 语法:
Mustache 的模板语法很简单,就那么几个:
- {{keyName}}
- {{#keyName}} {{/keyName}}
- {{^keyName}} {{/keyName}}
- {{.}}
- {{
- {{{keyName}}}
- {{!comments}}
这里将以 Javascript 应用为例进行介绍,先来看个 Demo:
...
<script type&#61;"text/Javascript" src&#61;"mustache.js">script> <script type&#61;"text/Javascript"> var data &#61; { "company": "Apple", "address": { "street": "1 Infinite Loop Cupertino", "city": "California ", "state": "CA ", "zip": "95014 " }, "product": ["Macbook ","iPhone ","iPod ","iPad "] } var tpl &#61; &#39;Hello {{company}}
&#39;; var html &#61; Mustache.render(tpl, data); console.log( html ) script> ... //运行后 Console 输出&#xff1a; <h1>Hello Appleh1>
在 Demo 中可以看到 data 是数据&#xff0c;tpl 是定义的模板&#xff0c;Mustache.render(tpl, data)
方法是用于渲染输出最终的 HTML 代码。
借助 Demo 来对语法做简单的介绍&#xff1a;
{{keyName}}
{{}}
就是 Mustache 的标示符&#xff0c;花括号里的 keyName 表示键名&#xff0c;这句的作用是直接输出与键名匹配的键值&#xff0c;例如&#xff1a;
var tpl &#61; &#39;{{company}}&#39;;
var html &#61; Mustache.render(tpl, data);
//输出&#xff1a;
Apple
{{#keyName}} {{/keyName}}
以#
开始、以/
结束表示区块&#xff0c;它会根据当前上下文中的键值来对区块进行一次或多次渲染&#xff0c;例如改写下 Demo 中的 tpl&#xff1a;
{{street}},{{city}},{{state}} 1 Infinite Loop Cupertino,California,CAvar tpl &#61; &#39;{{#address}}
var html &#61; Mustache.render(tpl, data);//输出&#xff1a;
注意&#xff1a;如果{{#keyName}} {{/keyName}}
中的 keyName 值为 null, undefined, false&#xff1b;则不渲染输出任何内容。
{{^keyName}} {{/keyName}}
该语法与{{#keyName}} {{/keyName}}
类似&#xff0c;不同在于它是当 keyName 值为 null, undefined, false 时才渲染输出该区块内容。
var tpl &#61; {{^nothing}}没找到 nothing 键名就会渲染这段{{/nothing}};
var html &#61; Mustache.render(tpl, data);
//输出&#xff1a;
没找到 nothing 键名就会渲染这段
{{.}}
{{.}}
表示枚举&#xff0c;可以循环输出整个数组&#xff0c;例如&#xff1a;
{{.}} Macbook iPhone iPod iPad var tpl &#61; &#39;{{#product}}
var html &#61; Mustache.render(tpl, data);
//输出&#xff1a;
{{>partials}}
以>
开始表示子模块&#xff0c;如{{> address}}&#xff1b;当结构比较复杂时&#xff0c;我们可以使用该语法将复杂的结构拆分成几个小的子模块&#xff0c;例如&#xff1a;
var tpl &#61; "
{{company}}
{{>address}}
"
var partials &#61; {address: "{{#address}}
var html &#61; Mustache.render(tpl, data, partials);
//输出&#xff1a;Apple
{{{keyName}}}
{{keyName}}
输出会将等特殊字符转译&#xff0c;如果想保持内容原样输出可以使用{{{}}}
&#xff0c;例如&#xff1a;
{{{street}}} 1 Infinite Loop Cupertinovar tpl &#61; &#39;{{#address}}
//输出&#xff1a;
{{!comments}}
!
表示注释&#xff0c;注释后不会渲染输出任何内容。
{{!这里是注释}}
//输出&#xff1a;
参考文章&#xff1a;
http://coenraets.org/blog/2011/12/tutorial-html-templates-with-mustache-js/
http://mustache.github.com/mustache.5.html
http://ued.xinyou.com/2012/07/mustache_5_document.html
来自&#xff1a;http://www.iinterest.net/2012/09/12/web-template-engine-mustache/