jquery - 获取 Handlebars 上的 key

标签 jquery handlebars.js

var data = {
   "name": "Jack",    
    "eventlist": {
        "1": {
           "title": "Title1"

    },
        "3": {
            "title": "Title2",

         }
    }
};

HTML

<div class="container">
<ul>
    <script id="list_template" type="text/x-handlebars-template">                                   
                <li>     

                </li>
            </script>   
        </ul>
</div>

我正在使用handlebar js进行模板化。我想知道如何迭代数据对象并打印“标题”以及相应的键“1”,“3”

最佳答案

您可以注册一个类似#each 的专用 block 帮助程序,它将散列/对象上下文的键与循环的“内部”上下文一起传递:

// based on the `#each` helper, requires jQuery (for jQuery.extend)
Handlebars.registerHelper('each_hash', function(context, options) {
    var fn = options.fn, inverse = options.inverse;
    var ret = "";

    if(typeof context === "object") {
        for(var key in context) {
            if(context.hasOwnProperty(key)) {
                // clone the context so it's not
                // modified by the template-engine when
                // setting "_key"
                var ctx = jQuery.extend(
                    {"_key":key},
                    context[key]);

                ret = ret + fn(ctx);
            }
        }
    } else {
        ret = inverse(this);
    }
    return ret;
});

当然,在渲染模板之前需要注册助手。

然后在您的模板中,您可以使用 _key 占位符引用 key :

<script id="list_template" type="text/x-handlebars-template">
     {{#each_hash eventlist}}
    <li>
        <span class="evl-key">{{_key}}</span> - 
            <span class="evl-title">{{title}}</span>
    </li>
    {{/each_hash}}
</script>

然后像任何其他 Handlebars 模板一样渲染模板:

var source = $("#list_template").html();
var template = Handlebars.compile(source);

var html = template(data);

$("div.container ul").append(html);

关于jquery - 获取 Handlebars 上的 key ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12032851/

相关文章:

jquery - 在 emberjs 中加载带有夹具数据的路线时出错

php - 在我的网站中通过鼠标右键单击来控制链接

javascript - jquery中的一键事件处理多个URL

jquery - 如何使用toggle()在jquery中设置cookie

java - jQuery 地址 - 表单提交后重定向

javascript - Handlebars 根据值渲染模板

javascript - 从 getElementById 加载图像时加载栏

javascript - 无法使用 API 的输入替换 Handlebars 变量

javascript - 使用 #each 内置 Handlebars 帮助器迭代对象时如何引用值?

javascript - Ember 问题: Uncaught Error: Could not find module handlebars