javascript - 如何动态更改数据表上的数据顺序(包括隐藏行)

标签 javascript html jquery datatables

我正在尝试更改 data-orderDataTable单击按钮时针对特定列。我尝试了两种解决方案,但都不起作用。第一个是迭代每个 <td>并更改 data-order属性为 HTML 标签内容的值,该标签具有由单击的按钮定义的类(存储在 className 中)。

这是代码:

let envTable = $('#env_table').DataTable();
$("td.env").each(function () {
    this.setAttribute('data-order', $(this).find(className).text().trim());
});

在函数结束时我这样做:

envTable.rows().invalidate().draw();

这不起作用,因为它仅迭代可见(未分页)的行,因此并未包含所有内容。

我尝试的另一个解决方案是更改 jQuery 使用的变量。我正在迭代每一行并选择一个单元格( value[2] 是该行中的第二个单元格)。我搜索我想要的值(如第一个解决方案中所示)。

let envTable = $('#env_table').DataTable();
const data = envTable.rows().data();
data.each(function (value, index) {
    const newDataOrder = $(value[2]['display']).filter(className).html().trim();
    value[2]['@data-order'] =  newDataOrder;
});

执行此代码后 data-order每个 <td> 中的属性没有改变,但 jQuery 使用的结构确实改变了。之后,表就可以正确排序了。如果已排序(例如升序),它将保留在 data-order 中。 (在 jQuery 数据中,而不是在 HTML 中)在排序之前设置的值(即使稍后更改,它们也不会影响排序)。

最佳答案

问题:

it iterates only through the visible (not paginated) rows

一种解决方案如下:

您可以迭代DataTable中的每一行(无论它是否在当前显示的记录中) - 并且您可以访问相应的HTML节点。

从那里,您可以根据需要操作data-order 属性。

envTable.rows().data().each( function ( rowData, index ) {
  var dataNode = envTable.cells(index, 0).nodes().to$()[0];
  console.log(dataNode); // just for testing
  console.log(dataNode.textContent); // just for testing
  $(dataNode).attr( "data-order", dataNode.textContent );
} );
envTable.rows().invalidate().draw();

这是一个小型的独立演示,其中包含一些测试数据来展示该过程:

<!doctype html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Demo</title>
  <script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
  <script src="https://cdn.datatables.net/1.10.21/js/jquery.dataTables.min.js"></script>
  <link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/1.10.21/css/jquery.dataTables.min.css">
  <link rel="stylesheet" type="text/css" href="https://datatables.net/media/css/site-examples.css">
</head>

<body>

<div style="margin: 20px;">

    <table id="env_table" class="display dataTable cell-border" 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 data-order="Nixon, Tiger">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 data-order="Winters, Garrett">Garrett Winters</td>
                <td>Accountant</td>
                <td>Tokyo</td>
                <td>63</td>
                <td>2011/07/25</td>
                <td>$170,750</td>
            </tr>
            <tr>
                <td data-order="Cox, Ashton">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 data-order="Kelly, Cedric">Cedric Kelly</td>
                <td>Senior Javascript Developer</td>
                <td>Edinburgh</td>
                <td>22</td>
                <td>2012/03/29</td>
                <td>$433,060</td>
            </tr>
            <tr>
                <td data-order="Satou, Airi">Airi Satou</td>
                <td>Accountant</td>
                <td>Tokyo</td>
                <td>33</td>
                <td>2008/11/28</td>
                <td>$162,700</td>
            </tr>
            <tr>
                <td data-order="Williamson, Brielle">Brielle Williamson</td>
                <td>Integration Specialist</td>
                <td>New York</td>
                <td>61</td>
                <td>2012/12/02</td>
                <td>$372,000</td>
            </tr>
            <tr>
                <td data-order="Chandler, Herrod">Herrod Chandler</td>
                <td>Sales Assistant</td>
                <td>San Francisco</td>
                <td>59</td>
                <td>2012/08/06</td>
                <td>$137,500</td>
            </tr>
            <tr>
                <td data-order="Davidson, Rhona">Rhona Davidson</td>
                <td>Integration Specialist</td>
                <td>Tokyo</td>
                <td>55</td>
                <td>2010/10/14</td>
                <td>$327,900</td>
            </tr>
            <tr>
                <td data-order="Hurst, Colleen">Colleen Hurst</td>
                <td>Javascript Developer</td>
                <td>San Francisco</td>
                <td>39</td>
                <td>2009/09/15</td>
                <td>$205,500</td>
            </tr>
            <tr>
                <td data-order="Frost, Sonya">Sonya Frost</td>
                <td>Software Engineer</td>
                <td>Edinburgh</td>
                <td>23</td>
                <td>2008/12/13</td>
                <td>$103,600</td>
            </tr>
            <tr>
                <td data-order="Gaines, Jena">Jena Gaines</td>
                <td>Office Manager</td>
                <td>London</td>
                <td>30</td>
                <td>2008/12/19</td>
                <td>$90,560</td>
            </tr>
            <tr>
                <td data-order="Flynn, Quinn">Quinn Flynn</td>
                <td>Support Lead</td>
                <td>Edinburgh</td>
                <td>22</td>
                <td>2013/03/03</td>
                <td>$342,000</td>
            </tr>
        </tbody>
    </table>
    
    <br>

 <button onclick="reOrder();">Click me</button> 

</div>

<script type="text/javascript">

  var envTable;

  function reOrder() {
    envTable.rows().data().each( function ( rowData, index ) {
      var dataNode = envTable.cells(index, 0).nodes().to$()[0];
      $(dataNode).attr( "data-order", dataNode.textContent );
    } );
    envTable.rows().invalidate().draw();
  }

  $(document).ready(function() {

    envTable = $('#env_table').DataTable();

} );

</script>

</body>
</html>

名称列中的每个值都包含一个data-order 属性。例如:

<td data-order="Nixon, Tiger">Tiger Nixon</td>

在我的测试数据中,我使用它按姓氏而不是名字对名称进行排序:

enter image description here

有一个按钮可以运行reOrder() 函数。这是行迭代发生的地方,也是访问 DOM 节点然后更改的地方。

就我而言,我更改了每个 data-order 属性,使其与显示名称匹配:

<td data-order="Tiger Nixon">Tiger Nixon</td>

重新绘制后,数据按名字排序显示。

关于javascript - 如何动态更改数据表上的数据顺序(包括隐藏行),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63598433/

相关文章:

javascript - 自定义 grunt 任务命名约定

javascript - 使用css隐藏第三个div内容

jquery - 切换菜单时背景变灰

JavaScript - 函数未定义

javascript - Magento 2中的可折叠js是否接受CSS图标内容:“content:”\e622”” ;?

javascript - 如何在php中实现多个复选框

jquery:将导航列表添加到滑动 div

c# - 无法获取换行符以在 aspx 页面上呈现

jquery - 将动态创建的元素添加到指令范围

javascript - 将 float 转换为至少保留一位小数的字符串(javascript)