Javascript 语言的模板引擎:Mustache
2016-03-18 14:06
549 查看
阅读目录
{{keyName}}
{{#keyName}} {{/keyName}}
{{^keyName}} {{/keyName}}
{{.}}
{{>partials}}
{{{keyName}}}
{{!comments}}
Web 模板引擎是为了使用户界面与业务数据(内容)分离而产生的,它可以生成特定格式的文档,通常是标准的 HTML 文档。当然不同的开发语言有不同模板引擎,如 Javascript 下的 Hogan 、ASP 下的 aspTemplate、以及 PHP 下的 Smarty,这里主要介绍基于 Javascript 语言的模板引擎,目前流行有 Mustache、Hogan、doT.js、JsRender、Kendo UI Templates等,jsperf.com 上可以看到它们的性能对比,首先先介绍下 Mustache。
{{keyName}}
{{#keyName}} {{/keyName}}
{{^keyName}} {{/keyName}}
{{.}}
{{<partials}}
{{{keyName}}}
{{!comments}}
这里将以 javascript 应用为例进行介绍,先来看个 Demo:
?
在 Demo 中可以看到 data 是数据,tpl 是定义的模板,
借助 Demo 来对语法做简单的介绍:
?
Demo 中的 tpl:
?
注意:如果
?
?
?
?
?
http://mustache.github.com/mustache.5.html
http://ued.xinyou.com/2012/07/mustache_5_document.html
来自:http://www.iinterest.net/2012/09/12/web-template-engine-mustache/
{{keyName}}
{{#keyName}} {{/keyName}}
{{^keyName}} {{/keyName}}
{{.}}
{{>partials}}
{{{keyName}}}
{{!comments}}
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}}
{{.}}
{{<partials}}
{{{keyName}}}
{{!comments}}
这里将以 javascript 应用为例进行介绍,先来看个 Demo:
?
Mustache.render(tpl, data)方法是用于渲染输出最终的 HTML 代码。
借助 Demo 来对语法做简单的介绍:
{{keyName}}
{{}}就是 Mustache 的标示符,花括号里的 keyName 表示键名,这句的作用是直接输出与键名匹配的键值,例如:
?
{{#keyName}} {{/keyName}}
以#开始、以
/结束表示区块,它会根据当前上下文中的键值来对区块进行一次或多次渲染,例如改写下
Demo 中的 tpl:
?
{{#keyName}} {{/keyName}}中的 keyName 值为 null, undefined, false;则不渲染输出任何内容。
{{^keyName}} {{/keyName}}
该语法与{{#keyName}} {{/keyName}}类似,不同在于它是当 keyName 值为 null, undefined, false 时才渲染输出该区块内容。
?
{{.}}
{{.}}表示枚举,可以循环输出整个数组,例如:
?
{{>partials}}
以>开始表示子模块,如{{> address}};当结构比较复杂时,我们可以使用该语法将复杂的结构拆分成几个小的子模块,例如:
?
{{{keyName}}}
{{keyName}}输出会将等特殊字符转译,如果想保持内容原样输出可以使用
{{{}}},例如:
?
{{!comments}}
!表示注释,注释后不会渲染输出任何内容。
?
参考文章:
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
来自:http://www.iinterest.net/2012/09/12/web-template-engine-mustache/
相关文章推荐
- 解析json实例
- javascript库之Mustache库使用说明
- JavaScript 解决 onblur 与 onclick 冲突
- js小问题
- JavaScript笔记1--this的含义
- javascript和excel和struts2的关联
- 拖拽 DIV 效果
- extjs button添加图标
- ant和opencv和javascript的关联
- 页面加载完成后自动执行一个方法函数的JQ、JS方法
- js 模块写法
- 一道阿里笔试题-javascript
- 深入理解JavaScript系列(5):强大的原型和原型链
- js关闭当前页面 (窗口)的几种方式总结
- Js操作cookie
- 用JS获取Html中所有图片文件流然后替换原有链接
- Javascript 检查字符串是否是数字的几种方法
- 前端工程师面试题JavaScript部分(第五季)
- jstl fmt标签
- Angular.js中的指令——易懂全解析