mustache语法

mustache 模板,用于构造html页面内容。在实际工作中,当同一个模板中想要调用不同的函数来渲染画面,在已经自定义好了的前提下,可以在渲染页面时对传入的参数进行手动判断。在不好判断的情况下,我们可以通过改变传入参数来进行判断。
Mustache 的模板语法很简单,就那么几个:

{{data}}
{{#data}} {{/data}}
{{^data}} {{/data}}
{{.}}
{{<partials}}
{{{data}}}
{{!comments}}

借助 Demo 来对语法做简单的介绍:

<script type="text/javascript" src="mustache.js"></script>
<script type="text/javascript">
var data = {
    "name": " xiaohua ",
    "msg": {
        "sex": " female ", 
        "age": " 22 ", 
        "hobit": " reading "
    },
    "subject": ["Ch","En","Math","physics"] ,
     "blank" : "&nbsp"
  }  

  var tpl = '<p> {{name}}</p>'; 
  var html = Mustache.render(tpl, data);

 alert ( html );
</script>
  • {{data}}
    {{}}就是 Mustache 的标示符,花括号里的 data 表示键名,这句的作用是直接输出与键名匹配的键值,例如:
var tpl = '{{name}}';
var html = Mustache.render(tpl, data);
//输出:
xiaohua
  • {{#data}} {{/data}}
    以#开始、以/结束表示区块,它会根据当前上下文中的键值来对区块进行一次或多次渲染,例如改写下 Demo 中的 tpl:
var tpl = '{{#msg}} <p>{{sex}},{{age}},{{hobit}}</p> {{/msg}}';
var html = Mustache.render(tpl, data); 
//输出:
<p> female, 22, reading</p>

注意:如果{{#data}} {{/data}}中的 data 值为 null, undefined, false;则不渲染输出任何内容。

  • {{^data}} {{/data}}
    该语法与{{#data}} {{/data}}类似,不同在于它是当 data值为 null, undefined, false 时才渲染输出该区块内容。
var tpl = {{^nothing}}没找到 nothing 键名就会渲染这段{{/nothing}};
var html = Mustache.render(tpl, data);
//输出:
没找到 nothing 键名就会渲染这段
  • {{.}}
    {.}}表示枚举,可以循环输出整个数组,例如:
var tpl = '{{#subject}} <p>{{.}}</p> {{/subject}}';
var html = Mustache.render(tpl, data);
//输出:
<p>Ch</p> <p>En</p> <p>Math</p> <p>physics</p>
  • {{>partials}}
    以>开始表示子模块,如{{> msg}};当结构比较复杂时,我们可以使用该语法将复杂的结构拆分成几个小的子模块,例如:
var tpl = "<h1>{{name}}</h1> <ul>{{>msg}}</ul>";
var partials = {msg: "{{#msg}}<li>{{sex}}</li><li>{{age}}</li><li>{{hobit}}</li>{{/msg}}"};
var html = Mustache.render(tpl, data, partials);
//输出:
<h1>xiaohua</h1>
<ul>
   <li>female</li>
   <li>22</li>
   <li>reading</li>
</ul>
  • {{{data}}}
    {{{data}}}输出会将特殊字符转义,而{{data}}不会转义直接输出,例如:
var tpl = "<h1>{{{blank}}}<h1>";
var html = Mustache.render(tpl, data);
//输出:
<h1>&nbsp;</h1>

如果是{{blank}}会输出<h1>&amp;nbsp</h1>。事实上{{{}}}在页面上显示的是一个空格,而{{}}在页面上显示&nbsp。

  • {{!comments}}
    !表示注释,注释后不会渲染输出任何内容。
var tpl = "<h1>{{!comments}}<h1>";
var html = Mustache.render(tpl, {comments : "注释"});
//输出:

在工作中,如果页面上的内容是从后台获取数据并渲染到页面上时,我们就可以使用mustache模板了,值得注意的是,render的数据一定要与键名相符合。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值