zoukankan      html  css  js  c++  java
  • mustache 模板,用于构造html页面内容

    Mustache 的模板语法很简单,就那么几个:

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

    ...
    <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"]
    }

    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 时才渲染输出该区块内容。

    1 var tpl = {{^nothing}}没找到 nothing 键名就会渲染这段{{/nothing}};
    2 var html = Mustache.render(tpl, data);
    3 //输出:
    4 没找到 nothing 键名就会渲染这段

    {{.}}

    {{.}}表示枚举,可以循环输出整个数组,例如:

    1 var tpl = '{{#subject}} <p>{{.}}</p> {{/subject}}';
    2 var html = Mustache.render(tpl, data);
    3 //输出:
    4 <p>Ch</p> <p>En</p> <p>Math</p> <p>physics</p>

    {{>partials}}

    >开始表示子模块,如{{> msg}};当结构比较复杂时,我们可以使用该语法将复杂的结构拆分成几个小的子模块,例如:

    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>
    <ul>
    <li>female</li>
    <li>22</li>
    <li>reading</li>
    </ul>

    {{{data}}}

    {{data}}输出会将等特殊字符转译,如果想保持内容原样输出可以使用{{{}}},例如:

    1 var tpl = '{{#msg}} <p>{{{age}}}</p> {{/msg}}'
    2 //输出:
    3 <p>22</p>

    {{!comments}}

    !表示注释,注释后不会渲染输出任何内容。

    1 {{!这里是注释}}
    2 //输出:
  • 相关阅读:
    【转】深入理解Java内存模型(二)——重排序
    mysql 查询表字段信息(字段名、描述、类型、长度)
    SQL-Server随机日期值
    浏览器一直不停的异步请求(环境:vs.net mvc)
    asp.net mvc 默认首页设置静态文件
    字符串转json对象 SyntaxError: missing ; before statement
    SQL Server 自增标识位插入显示值
    c# 去除字符串中的换行符 " "
    处理SQL注入参考
    多线程简单应用示例
  • 原文地址:https://www.cnblogs.com/aashui/p/9196046.html
Copyright © 2011-2022 走看看