addClass到handlebar脚本

时间:2015-11-02 11:58:57

标签: javascript jquery handlebars.js addclass

是否有一种简单的方法可以将一个类添加到手柄脚本中的表行中?

现在我正在循环使用JSON,并希望将pagenumber类添加到所有行

for (var i = 0; i < allData.length; i++) {

        if (i % 10 == 0 && i != 0) {
            pageNumber++;                             
        }
        $('.tableRow').addClass('page' + pageNumber);
        console.log("page" + pageNumber);
    } 

.tableRow是<tr>我的车把脚本

一切正常,但我无法添加到该课程。如果我尝试附加到我的脚本之外的类

,它可以正常工作

HTML code:

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <link rel="stylesheet" type="text/css" media="screen" href="/includes/css/style.css" />
</head>
<body>
    <div class="wrapper">
        <div class="tab-container">

            <div class="tab-content">

                <div id="scriptData"></div>


                <script id="template" type="text/x-handlebars-template">


                        <table class="table-look">
                            <thead>
                                <tr>
                                    <th class="Header">Some data</th>
                                    <th class="Header">Some data</th>
                                    <th class="Header">Some data</th>
                                    <th class="Header">Some data</th>
                                </tr>
                            </thead>
                            <tbody>
                                {{#each this}}
                                <tr class="tableRow">
                                    <td">{{data}}</td>
                                    <td>{{data}}</td>
                                    <td>{{data}}</td>
                    <td>{{data}}</td>                               
                                </tr>
                    {{/each}} 
                            </tbody>                           
                        </table>
                </script>

            </div>
        </div>
    </div>

    <script type="text/javascript" src="includes/js/libs/jquery-1.11.3.min.js"></script>
    <script src="includes/js/libs/handlebars-v4.0.2.js"></script>
    <script type="text/javascript" src="includes/js/custom.js"></script>
</body>
</html>

2 个答案:

答案 0 :(得分:1)

我见过HandlebarJS有点ban,,但我自己从未使用过 - 所以这似乎是一个抓住它的好机会。

jQuery不会接受<script id="..." type="text/x-handlebars-template">中的任何元素。你没有任何DOM元素供jQuery使用 - 你刚刚得到了一些文字。它有点令人困惑,因为它看起来像普通的HTML元素 - 但它只是文本。这是一个剧本。

您有两个选择 - 您可以:

  • 答:在渲染模板后循环遍历DOM元素。
  • B:使用Handlebar的Block Expressions

选项A:

$(document).ready(function () {
    var source = $("#template").html();
    var template = Handlebars.compile(source);
    var html = template(context);
    $('#foo').html(html);
    $('.tableRow').each(function(idx,o){
        $(this).addClass('page'+Math.floor(idx/2));
    });
});

http://jsfiddle.net/daveSalomon/xzey0dnj/3/

选项B:

<强>模板

<tr class = "tableRow {{#page-number}}page{{/page-number}}">

<强> JS

var fooItemNumber = 0;
Handlebars.registerHelper('page-number', function(items, options) {
    var out = "page";
    return out + Math.floor(fooItemNumber++/2);
});

http://jsfiddle.net/daveSalomon/xzey0dnj/5/

答案 1 :(得分:0)

试试这个

$documents