繁体   English   中英

使用handlebars.js做出“ if x in dict(json)”语句

[英]Making a “if x in dict(json)” statement with handlebars.js


我正在尝试将Django模板转换为Handlebars.js模板。 在Django模板中,我使用了:
if forloop.counter in Dinsdag
我正在尝试在Handlebars.js中创建一个做同样事情的自定义帮助程序。 这是我到目前为止的内容:

helper.js:

Handlebars.registerHelper('isIn', function(waarde, inWaarde){
   $.each($.parseJSON(inWaarde), function(k, v) {
        if (k == waarde){
            return options.fn(this);
        }
   });
    return options.inverse(this);
});

data.js:

$(function(){
    var templateScript = $("#entry-template").html();
    var theTemplate = Handlebars.compile(templateScript);
    var context = {  "dinsdag": {
                        "uitval2": {
                          "7": "1",
                          "9": "1",
                          "11": "1"
                        },}}
    var html = theTemplate(context);
    $('.test').html(html);
    $(document.body).append(html);
})

index.html:

<html>
<head>
 <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/handlebars.js/4.0.5/handlebars.min.js">
     </script>
     <script type="text/javascript" src="
https://cdnjs.cloudflare.com/ajax/libs/jquery/3.0.0-beta1/jquery.js"></script>
    <script src="helper.js"></script>
    <script src="data.js"></script>
 </head>
<body>  
   <script id="entry-template" type="text/x-handlebars-template">
       <ul class="test"> 
           {{#dinsdag}}
                    {{#isIn 7 uitval2}}
                        <p>klopt</p>
                    {{else}}
                        <p>mwah</p>
                    {{/isIn}}
           {{/dinsdag}}
       </ul>
    </div>
  </div>
</script> 
</body>
</html>

这不会在屏幕上显示任何内容,并出现以下错误:
Uncaught SyntaxError: Unexpected token o

希望有人能帮上忙。 请记住,我完全是Handlebars.js的菜鸟

因此,问题在于Handlebars自动将JSON “字符串化”。
虽然删除$.parseJSON并不能解决问题,但我必须指定jQueryJSON
我这样做是这样的:
$.each($.parseJSON(JSON.stringify(inWaarde))

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM