zoukankan      html  css  js  c++  java
  • 模板引擎之hogan.js

    hogan.js 语法简单,且支持循环数据:

    基本语法:

      1. 标签可以嵌套使用

      2. {{data}} 转义的变量,不会渲染html标签

      3. {{{data}}} 不转义的变量,会渲染html标签,比如接口返回的富文本编辑器的内容

      4. {{#list}} {{/list}} 列表循环 / 真值判断,只能循环数组,不能循环字符串

      5. {{^list}} {{/list}} 空列表 / 非真值判断

      6. {{.}} 枚举的当前元素  //一般都是枚举数组,不能枚举字符串

      7. {{!}} 我是注释

    注意事项:

         1. hogan.js 如需做接口数据的逻辑处理,可以先用jqery循环再用hogan去渲染   

         例如: 一个数组Arr包括6个对象,如果只渲染Arr的话  1. 可以直接将 Arr丢给 hogan去渲染,2. 也可以 将Arr用jquery循环后得到每一个对象再丢给hogan去渲染;如需取到数组中每一个对象的id,然后根据这个id去做其他的操作,只能用第2种方法,因为第1种方法不好保存循环出来的每一项的id,第2种方法可以保存,所以应该先用jqery去循环数组Arr,得到每一个对象后再用hogan去渲染AA()函数,得到每一个对象的id再去做其他操作;         

              $(Arr).each(function (key,val) {
    
                 //数据渲染
                 AA(val);  用hogan去渲染
    
                //其他操作
    
                BB(val.id); 用hogan去渲染
    
               }) 

         2. 接口是对象形式  {"aa": bb} ,可以直接取到  aa

         3. 接口是两层或两层以上的数据循环  把接口数据当做标签循环

         4. 接口是数组形式 [aa,bb],  用枚举 {{.}}  取到 

         5. 可以给对象添加一个字段/属性再用hogan渲染出来   obj.aa= bb;

         6. hogan本身支持es6模板字符串,如下所示,但是在前后端不彻底分离的情况下很可能会与后端的模板引擎冲突$,导致可以使用``,不能使用$,此时注意:写在html文件中会冲突,单独写在js文件中不会冲突,所以建议把逻辑写在单独的js文件。

          `{{#listaa}}
             <ul>
                <div>我叫{{name}},code=${code}</div>
            </ul>
         {{/listaa}}`;

          7. 

    
    

       

    参考文档:http://www.imooc.com/article/18493    https://segmentfault.com/a/1190000011401896 

    github地址:https://github.com/twitter/hogan.js    官网:https://twitter.github.io/hogan.js/

    亦可引用BootCDN:BootCDN

    一、实际项目中的用法如下:

    实际项目中的用法:
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.js"></script>
    <script src="https://cdn.bootcss.com/hogan.js/3.0.2/hogan.js"></script>

    <script>

    // 取接口数据
    $.ajax({
    url: "1.json",
    //type: "post",
    dataType: "json",
    data: {
    //"appUserId": appUserId,
    //"courseId": courseId
    },
    success: function (response) {
    console.log(response);
    var data = response.data;
    console.log(data);
    // 渲染数据
    bind(data);
    }
    })
    // 渲染数据
    function bind(data) {
    var tpl =
    `{{#listaa}}
    <ul>
    <div>我叫{{name}},我今年{{age}}岁,我喜欢吃{{food}}</div>
    {{#videoList}}
    <li>{{fileName}}</li>
    {{/videoList}}

    {{!注释: 指定渲染的数据对象后,下面的数据都可以直接用 标签名=数据名,比如此处的videoList}}
    </ul>
    {{/listaa}}`;
    var result = Hogan.compile(tpl).render({
    //指定渲染的数据对象,指定渲染的数据对象后,下面的数据都可以直接用 标签名=数据名
    listaa: data
    });
    // 最后添加到指定标签
    $('.box').append(result);
    }

    </script>

     对应的请求到的 json 数据如下:

    
    

     对应的请求到的 json 数据如下:

    {
      "result": true,
      "codeDesc": "获取视频成功",
      "code": "1",
      "data": [
        {
          "name": "lily",
          "age": 18,
          "food": "苹果",
          "videoList": [
            {
              "fileName": "aa"
            }
          ]
        },
        {
          "name": "lucy",
          "age": 20,
          "food": "香蕉",
          "videoList": [
            {
              "fileName": "cc"
            },
            {
              "fileName": "dd"
            }
          ]
        }
      ],
      "msg": "获取视频成功"
    }

    二、详细使用文档

      由于公司jsp项目中不支持 ` ` 模板字符串的用法(因为${} 的语法和jsp有冲突),所以本人无意中发现有 hogan.js 这个模板引擎,因为它的语法是 {{}},不会和jsp冲突。


    <
    script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.js"></script> <script src="https://cdn.bootcss.com/hogan.js/3.0.2/hogan.js"></script> <div id="box"> </div> <script> // 保存接口数据的对象 var obj = { data: { "list": [], "num": [1,2,3], "isme": true,//true显示 不显示包括:false、null、undefined、0
           "msg":"信息",
            },
            onload: function () {
                // 定义模板
                // 有key的循环
                var tpl =
                    `{{#list}}
                    <div>我叫{{name}}, 今年{{age}}岁, 最爱吃{{food}}</div>
                    {{/list}}`;
                var template = Hogan.compile(tpl);
                var result = template.render({list: this.data.list});
    
                // 没有key的循环 只能这样写
    //            var tpl =
    //                `{{#list}}
    //                <div>我叫{{.}}</div>
    //                {{/list}}`;
    //            var template = Hogan.compile(tpl);
    //            var result = template.render({list: this.data.num});
    
                // 对象型用法
    //            var tpl =
    //                `{{#list}}
    //                <div>我叫{{msg}}</div>
    //                {{/list}}`;
    //            var template = Hogan.compile(tpl);
    //            var result = template.render({list: this.data});
    
                // 布尔型用法
    //            var tpl =
    //                `{{#list}}
    //                <div>我叫张瑞奇</div>
    //                {{/list}}`;
    //            var template = Hogan.compile(tpl);
    //            var result = template.render({list: this.data.isme});
    
                // 最后添加到指定标签
                $('.box').html(result)
            }
        }
        // 取接口数据
        $.ajax({
            url: "${ctxStatic}/z-img/1.json",
            //type: "post",
            dataType: "json",
            data: {
                //"appUserId": appUserId,
                //"courseId": courseId
            },
            success: function (response) {
                console.log(response);
                var _data = response.data.dataList;//数组
                console.log(_data);
                // 将取到的数据赋值给obj的data.list
                obj.data.list = _data;
                console.log(obj.data.list);
                // 渲染完成
                obj.onload();
                // 其他操作
    
            }
        })
    
    
    
    </script>

     两层循环(及两层以上)用法:

    1. 两层循环标准的写法如下,项目中使用这种写法:

    两层循环
    <script>
        var tab = {
            data: {
                "aa": [
                    {
                        "name": "lily",
                        "age": 18,
                        "food": "苹果",
                        "videoList": [
                            {
                                "fileName": "aa",
                            }
                        ]
                    },
                    {
                        "name": "lucy",
                        "age": 20,
                        "food": "香蕉",
                        "videoList": [
                            {
                                "fileName": "cc",
                            },
                            {
                                "fileName": "dd",
                            }
                        ]
                    }
                ]
            },
            onload: function () {
                var tpl =
                    `{{#listaa}}
                    <ul>
                        <div>我叫{{name}},我今年{{age}}岁,我喜欢吃{{food}}</div>
                        {{#videoList}}
                        {{!注释: 指定渲染的数据对象后,下面的数据都可以直接用 标签名=数据名}}
                        <li>{{fileName}}</li>
                        {{/videoList}}
                    </ul>
                    {{/listaa}}`;
                var template = Hogan.compile(tpl);
                var result = template.render({
                    listaa: this.data.aa //指定渲染的数据对象
                });
                // 最后添加到指定标签
                $('.box').append(result);
    
            }
        }
        // 调用
        tab.onload();
    
    </script>

    2. 这种写法是 和jquery相结合的,不推荐此种写法,建议使用上面的第一种写法

    <script>
        var tab = {
            data: {
                "list": [
                    {
                        "name": "lily",
                        "age": 18,
                        "food": "苹果",
                        "videoList": [
                            {
                                "fileName": "aa",
                            },
                            {
                                "fileName": "bb",
                            }
                        ]
                    },
                    {
                        "name": "lucy",
                        "age": 20,
                        "food": "香蕉",
                        "videoList": [
                            {
                                "fileName": "cc",
                            },
                            {
                                "fileName": "dd",
                            }
                        ]
                    }
                ],
                "num": [1, 2, 3],
                "isme": true,//true显示 false不显示
                "msg": "信息",
            },
            onload: function () {
                // 定义模板
                // 两层循环
                var tpl =
                    `<ul>
                        {{#aa}}
                        <div>{{name}}</div>
                        {{/aa}}
                        {{#bb}}
                        <li>{{fileName}}</li>
                        {{/bb}}
                    </ul>`;
                var template = Hogan.compile(tpl);
                $(this.data.list).each(function (key,val) {
                    //console.log(val);
                    var result = template.render({
                        aa: val,
                        bb: val.videoList
                    });
                    // 最后添加到指定标签
                    $('.box').append(result);
                })
            }
        }
        // 调用
        tab.onload();
    
    </script>

     

  • 相关阅读:
    绘图类
    画笔类
    创建模态,非模态对话框
    菜单类
    [WPF]程序随系统自启动
    [WPF]xml序列化以及反序列化数据
    [WPF]项目整合Metro和MaterialDesignInXamlToolkit UI框架
    [WPF]鼠标移动到Button颜色改变效果设置
    [Leetcode] 寻找数组的中心索引
    [Leetcode]在排序数组中查找元素的第一个和最后一个位置
  • 原文地址:https://www.cnblogs.com/zhangruiqi/p/8547268.html
Copyright © 2011-2022 走看看