zoukankan      html  css  js  c++  java
  • Handlebars模板引擎渲染页面

    基本使用,并简单列举了几种常见的数据格式的渲染方式

    js:
    var testTpl = Handlebars.compile($('#test').html()); //模板
        var arr = [1,2,3] //数据
        $('#box').append(testTpl(arr)); //调用

    html: <script type="text/x-handlebars-template" id="test"> {{#each this}} <li>索引:{{@index}},内容:{{this}}</li> {{/each}} </script>

    下面说几种数据源如何渲染数据,js中基本一样,声明模板->声明要渲染数据->调用并插入到页面 ,不明白看 上面基本使用

    数据源是Array 

    js:
    var arr = [1,2,3]
    html:
    {{#each this}}
            <li>索引:{{@index}},内容:{{this}}</li>
    {{/each}}

    数据源是数组对象(对象内部包含数组,再次each这个数组即可

    js:
    var arr = [
        {'a':'1','b':2,'c':['4','5','6']},
        {'a':'11','b':22,'c':['44','55','66']}
     ];
    html:
    {{#each this}}
        <li>{{a}}</li>
        <li>{{b}}</li>
        {{#each c}}
            <li>父级索引{{../a}}.{{@index}}:访问父级:{{../a}} 。当前索引:{{@index}},当前元素:{{this}} </li>
        {{/each}}
    {{/each}}

    数据源是对象

    js:
    var context = {
        data:{
            one: "un",
            two: "deux",
            three: "trois"
        }
    }
    html:
    <ul>
        {{#each data}}
            <li>对象的key:{{@key}},对象的值:{{this}}</li>
        {{/each}}
    </ul>
    <ol>
        {{#each data}}
            <li>对象的索引:{{@index}},对象的值:{{this}}</li>
        {{/each}}
    </ol>

    数据源数对象数组

    js:
    var context = {
                data: ["one", "two", "three"],
                data2: ["one", "two", "three"],
            };
    html:
    <ul>
        {{#each data}}
            <li>
                数组的索引:{{@index}} ,索引对应的内容:{{this}}{{#eq @index 0}}王生辉{{/eq}}
            </li>
        {{/each}}
        {{#each data2}}
            <li>
                数组的索引:{{@key}},索引对应的内容:{{shenghui this}}
            </li>
        {{/each}}
    </ul>

    说明:@key 和@index 

         @key:如果当循环的数据是数组 则返回下标,如果是对象则返回key值

       @index:都返回下标

     

     

     

     

     

     

     

     

     

     

  • 相关阅读:
    python与常用模块pandas,numpy,matplotlib等库学习笔记-2019.02.07更新
    C++异常处理相关用法及底层机制
    C++ regex库常用函数及实例
    leetcode-2-两数相加(链表)
    leetcode-1-两数之和(三种方法)
    中序遍历(递归+迭代)
    C++实现四则运算器(带括号)
    C++实现四则运算器(无括号)
    Visual Studio2019 基于WSL的Linux C++开发
    Visual Studio 2019 基于Linux平台的C++开发
  • 原文地址:https://www.cnblogs.com/NTWang/p/7368014.html
Copyright © 2011-2022 走看看