当行具有或不具有 colspan 时,表中的排序不起作用

发布于 2024-12-22 06:19:03 字数 979 浏览 0 评论 0原文

我有一个显示事件列表的表格,每个事件还有一个最初隐藏的详细信息行,通过单击按钮将变得可见。

标记看起来像这样:

<table>
   <thead>
      <tr>
         <th>Header 1</th>
         <th>Header 2</th>
         <th>Header 3</th>
      </tr>
   </thead>
   <tbody>
      <tr class="i-am-always-visible">
         <td>Event date</td>
         <td>Event name</td>
         <td>Event location</td>
      </tr>
      <tr>
         <td colspan="3" class="i-am-hidden-by-default">
            Contact form
         </td>
      </tr>
   </tbody>
</table>

这是我用于设置可排序表的 JS

$('#tableId').dataTable({
   "bPaginate": false,
   "bAutoWidth": false
});

没有棘手的部分:我想使用 jQuery 插件 dataTables 使表可排序,但它似乎无法处理带有 colspan 的行我找不到任何可以在初始化时传递给 dataTables 以正确处理这些行的配置选项。

有没有人遇到过同样的问题并解决了它,或者可以向我指出有关此问题的正确信息?

提前致谢!

I have a table that shows a list of events, each event also has a detail row that is initially hidden and will become visible by clicking a button.

The markup looks like this:

<table>
   <thead>
      <tr>
         <th>Header 1</th>
         <th>Header 2</th>
         <th>Header 3</th>
      </tr>
   </thead>
   <tbody>
      <tr class="i-am-always-visible">
         <td>Event date</td>
         <td>Event name</td>
         <td>Event location</td>
      </tr>
      <tr>
         <td colspan="3" class="i-am-hidden-by-default">
            Contact form
         </td>
      </tr>
   </tbody>
</table>

This is the JS I use for setting up my sortable table

$('#tableId').dataTable({
   "bPaginate": false,
   "bAutoWidth": false
});

No the tricky part comes in: I want to make the table sortable with the jQuery plugin dataTables and it seems like it can't handle rows with a colspan and I couldn't find any configuration option I could pass to dataTables on initialization to handle these rows properly.

Has anyone came across the same issue and solved it or can point me to the right place information regarding this issue is available?

Thanks in advance!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

药祭#氼 2024-12-29 06:19:03

实际上,我在网上找到的任何库/脚本似乎都不可能做到这一点。看来这是一项相当艰巨的任务。我最终使用 knockout.js 来实现我需要的结果。它对 SEO 非常不友好,因此在使用它之前请三思;-) 在我的情况下,这是不需要的。

如果有人想做同样的事情,这里有一些基本的 Knockout.js 代码:

function myViewModel() {
     var self = this;

     self.data = ko.observableArray([
          {"id":1, "date":"2012/01/01", "name":"bar", "location":"New York City"},
          {"id":2, "date":"2012/01/01", "name":"bar", "location":"New York City"},
          {"id":3, "date":"2012/01/01", "name":"bar", "location":"New York City"}
     ]);

     self.sortData = function() {
          self.data.sort(function(left, right) {
               // ... custom sorting code ...
          });
     }
}

视图

<table>
     <thead>
        <tr>
           <th>ID</th>
           <th>Name</th>
           <th>Location</th>
        </tr>           
     </thead>
     <tbody data-bind="foreach: data">
        <tr class="i-am-always-visible">
           <td data-bind="text: id"></td>
           <td data-bind="text: name"></td>
           <td data-bind="text: location"></td>             
        </tr>
        <tr>
           <td colspan="3" class="i-am-hidden-by-default">
              Contact form
           </td>
        </tr>
     </tbody>
</table>

它是如何工作的?
通常,对 HTML 表进行排序的脚本会对 HTML 节点进行排序,因为它们对数据源一无所知。使用knockout.js,您可以对数据源进行排序,然后它会负责重新绘制表行,无论您有多少列:-)

希望它也对其他人有帮助!

Actually it seems that this is not possible with any library/script I found on the web. Seems like it's a pretty hard task. I ended up using knockout.js to achieve the result I need. It's very SEO unfriendly, so think about twice before using it ;-) In my case this was not needed.

If anyone wants to do the same thing, here's some basic knockout.js code:

function myViewModel() {
     var self = this;

     self.data = ko.observableArray([
          {"id":1, "date":"2012/01/01", "name":"bar", "location":"New York City"},
          {"id":2, "date":"2012/01/01", "name":"bar", "location":"New York City"},
          {"id":3, "date":"2012/01/01", "name":"bar", "location":"New York City"}
     ]);

     self.sortData = function() {
          self.data.sort(function(left, right) {
               // ... custom sorting code ...
          });
     }
}

The view

<table>
     <thead>
        <tr>
           <th>ID</th>
           <th>Name</th>
           <th>Location</th>
        </tr>           
     </thead>
     <tbody data-bind="foreach: data">
        <tr class="i-am-always-visible">
           <td data-bind="text: id"></td>
           <td data-bind="text: name"></td>
           <td data-bind="text: location"></td>             
        </tr>
        <tr>
           <td colspan="3" class="i-am-hidden-by-default">
              Contact form
           </td>
        </tr>
     </tbody>
</table>

How does it work?
Usually the scripts that sort HTML tables sort the HTML nodes as they don't know anything about the data source. With knockout.js you sort the data source and it then takes care of redrawing the table rows, no matter how much colspans you have :-)

Hope it also helps somebody else!

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文