用cell()实现eq选择器.data()

时间:2018-03-15 16:35:33

标签: javascript jquery

请检查以下示例。在javascript部分的底部,您将看到一个数据表框架函数cell()。data()用于更改第一个< td>文本,但我没有选择任何特定的< td>所以默认情况下这会改变第一个< td>。但我的目标是我想选择我的“< td>”用“$ row.find('td:eq(2)'))”jquery函数。但请记住,我必须使用cell()。data()函数来更改文本。总之,实际上我想用jquery eq选择器控制cell。()。data()。我该怎么办?

注意:我在此示例中使用datatables framework

<!DOCTYPE html>
<html>
<head>
    <title>Demo</title>
    <link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/1.10.16/css/jquery.dataTables.min.css">
    <script type="text/javascript" charset="utf8" src="https://code.jquery.com/jquery-1.12.4.js"></script>
    <script type="text/javascript" charset="utf8" src="https://cdn.datatables.net/1.10.16/js/jquery.dataTables.min.js"></script>

</head>
<body>

<table id="example" class="display" style="width:100%">
        <thead>
            <tr>
                <th>Name</th>
                <th>Position</th>
                <th>Office</th>
                <th>Age</th>
                <th>Start date</th>
                <th>Salary</th>
            </tr>
        </thead>
        <tbody>
            <tr>
                <td>Tiger Nixon</td>
                <td>System Architect</td>
                <td>Edinburgh</td>
                <td>61</td>
                <td>2011/04/25</td>
                <td>$320,800</td>
            </tr>
            <tr>
                <td>Garrett Winters</td>
                <td>Accountant</td>
                <td>Tokyo</td>
                <td>63</td>
                <td>2011/07/25</td>
                <td>$170,750</td>
            </tr>
            <tr>
                <td>Ashton Cox</td>
                <td>Junior Technical Author</td>
                <td>San Francisco</td>
                <td>66</td>
                <td>2009/01/12</td>
                <td>$86,000</td>
            </tr>
            <tr>
                <td>Cedric Kelly</td>
                <td>Senior Javascript Developer</td>
                <td>Edinburgh</td>
                <td>22</td>
                <td>2012/03/29</td>
                <td>$433,060</td>
            </tr>
        </tbody>
    </table>

<script type="text/javascript">

$(document).ready(function() {
    $('#example').DataTable();

    //$row.find('td:eq(2)'));

    var table = $('#example').DataTable();
    table.cell().data("fooo");


});


</script>

</body>
</html>

2 个答案:

答案 0 :(得分:0)

您可以遍历所有单元格并过滤列索引。 因此,一旦获得正确的单元格,您可以根据需要设置属性数据。

table.cells( function ( idx, data, node ) {
    if(idx.column == 2) {
      table.cell(idx).data("fooo");
    }
});

请参阅以下摘录:

&#13;
&#13;
$(document).ready(function() {
    var table = $('#example').DataTable();
    var test = table.cells( function ( idx, data, node ) {
        if(idx.column == 2) {
          table.cell(idx).data("fooo");
        }
    } );
});
&#13;
<link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/1.10.16/css/jquery.dataTables.min.css">
<script type="text/javascript" charset="utf8" src="https://code.jquery.com/jquery-1.12.4.js"></script>
<script type="text/javascript" charset="utf8" src="https://cdn.datatables.net/1.10.16/js/jquery.dataTables.min.js"></script>

<table id="example" class="display" style="width:100%">
    <thead>
        <tr>
            <th>Name</th>
            <th>Position</th>
            <th>Office</th>
            <th>Age</th>
            <th>Start date</th>
            <th>Salary</th>
        </tr>
    </thead>
    <tbody>
        <tr>
            <td>Tiger Nixon</td>
            <td>System Architect</td>
            <td>Edinburgh</td>
            <td>61</td>
            <td>2011/04/25</td>
            <td>$320,800</td>
        </tr>
        <tr>
            <td>Garrett Winters</td>
            <td>Accountant</td>
            <td>Tokyo</td>
            <td>63</td>
            <td>2011/07/25</td>
            <td>$170,750</td>
        </tr>
        <tr>
            <td>Ashton Cox</td>
            <td>Junior Technical Author</td>
            <td>San Francisco</td>
            <td>66</td>
            <td>2009/01/12</td>
            <td>$86,000</td>
        </tr>
        <tr>
            <td>Cedric Kelly</td>
            <td>Senior Javascript Developer</td>
            <td>Edinburgh</td>
            <td>22</td>
            <td>2012/03/29</td>
            <td>$433,060</td>
        </tr>
    </tbody>
</table>
&#13;
&#13;
&#13;

我希望它可以帮助你,再见。

答案 1 :(得分:0)

如果您只想更改第一个单元格,可以将jQuery节点传递给table.cell()方法,这样就行了,如果我理解正确,将会执行以下操作:

table.cell($('#example td:eq(2)')).data("fred")