什么是Mustache?
Mustache是一个logic-less(轻逻辑)模板解析引擎,它是为了使用户界面与业务数据(内容)分离而产生的,它可以生成特定格式的文档,通常是标准的HTML文档。当同一个模板中想要调用不同的函数来渲染画面,在已经自定义好了的前提下,可以在渲染页面时对传入的参数进行手动判断。
比如小程序的wxml中的代码:
- // 这里的{{ }}就是Mustache的语法。
- <text>{{userInfo.nickName}}</text>,
- {{keyName}}
- {{{keyName}}}
- {{#keyName}} {{/keyName}}
- {{^keyName}} {{/keyName}}
- {{.}}
- {{!comments}}
- {{>partials}}
-
- var data = { "name": "weChat" };
- Mustache.render("{{name}} is excellent.",data);
- 返回 weChat is excellent.
- 如:<br>、<tr>等而不想转义,可以在用{{&name}}
- var data = {
- "name" : "<br>weChat<br>"
- };
- var output = Mustache.render("{{&name}} is excellent.", data);
- console.log(output);
- 返回:<br>weChat<br> is excellent.
- 去掉"&"的返回是转义为:<br>weChat<br> is excellent.
- 另外,你也可以用{{{ }}}代替{{&}}。
- var data = {
- "stooges" : [ {
- "name" : "Moe"
- }, {
- "name" : "Larry"
- }, {
- "name" : "Curly"
- };
- var output = Mustache.render("{{#stooges}}<b>{{name}}</b>{{/stooges}}",
- data);
- console.log(output);
- 返回:<b>Moe</b>
- <b>Larry</b>
- <b>Curly</b>
该语法与{{#keyName}} {{/keyName}}类似,不同在于它是当keyName值为null, undefined, false时才渲染输出该区块内容。比如:
- var data = {
- "name" : "<br>weChat<br>"
- };
- var tpl = ‘{{^nothing}}没找到 nothing 键名就会渲染这段{{/nothing}}’;
- var output = Mustache.render(tpl, data);
- 返回:没找到 nothing 键名就会渲染这段
- var data = {
- "product": ["Macbook ","iPhone ","iPod ","iPad "]
- }
- var tpl = '{{#product}} <p>{{.}}</p> {{/product}}';
- var html = Mustache.render(tpl, data);
- 返回:<p>Macbook </p> <p>iPhone </p> <p>iPod </p> <p>iPad </p>
- {{!这里是注释}}
以>开始表示子模块,当结构比较复杂时,我们可以使用该语法将复杂的结构拆分成几个小的子模块。
- var tpl = "<h1>{{namme}}</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>
{{data}} 输出会将等特殊字符转译,如果想保持内容原样输出可以使用{{{}}},
- var tpl = '{{#msg}} <p>{{{age}}}</p> {{/msg}}'
- //输出:
- <p>22</p>
小程序 这么多大致就能用了,如果发现什么其他的再更新。。。