使用JQuery展开/折叠表行

我想在单击标题列时展开和折叠表格行。我只想展开/折叠在特定标题(点击)下的行。

这里是我的表结构:

<table border="0">
  <tr>
    <td colspan="2">Header</td>
  </tr>
  <tr>
    <td>data</td>
    <td>data</td>
  </tr>
  <tr>
    <td>data</td>
    <td>data</td>
  </tr>
  <tr>
    <td colspan="2">Header</td>
  </tr>
  <tr>
    <td>date</td>
    <td>data</td>
  </tr>
  <tr>
    <td>data</td>
    <td>data</td>
  </tr>
  <tr>
    <td>data</td>
    <td>data</td>
  </tr>
</table>

任何想法如何我可以完成这个任务。使用div这个任务看起来很简单,但我有表格数据,我想操纵。

我可以想到的一个想法是在每个行中使用css类,区分每个标题下的行,并使用JQuery扩展/折叠那些行,只有当标题被点击。但是如果我的表有10-15头,那么似乎很难跟踪css类。

请建议一个合适的方法来实现这一点。

解决方法

你可以这样尝试: –

给一个类说标题标题行,使用nextUntil获取点击标题下的所有行,直到下一个标题

JS

$('.header').click(function(){
    $(this).nextUntil('tr.header').slideToggle(1000);
});

Html

<table border="0">
  <tr  class="header">
    <td colspan="2">Header</td>
  </tr>
  <tr>
    <td>data</td>
    <td>data</td>
  </tr>
  <tr>
    <td>data</td>
    <td>data</td>
  </tr>

Demo

另一个例子:

$('.header').click(function(){
   $(this).find('span').text(function(_,value){return value=='-'?'+':'-'});
    $(this).nextUntil('tr.header').slideToggle(100); // or just use "toggle()"
});

Demo

您还可以使用promise在切换完成后切换span图标/文本(如果是动画切换)。

$('.header').click(function () {
    var $this = $(this);
    $(this).nextUntil('tr.header').slideToggle(100).promise().done(function () {
        $this.find('span').text(function (_,value) {
            return value == '-' ? '+' : '-'
        });
    });
});

.promise()

.slideToggle()

或者只需使用css伪元素来表示展开/折叠的符号,并且只需切换标题上的类。

CSS: –

.header .sign:after{
  content:"+";
  display:inline-block;      
}
.header.expand .sign:after{
  content:"-";
}

JS: –

$(this).toggleClass('expand').nextUntil('tr.header').slideToggle(100);

Demo

相关文章

jQuery插件的种类 1、封装对象方法 这种插件是将对象方法封装起来,用于对通过选择器获取的jQuery对象进...
扩展jQuery插件和方法的作用是非常强大的,它可以节省大量开发时间。 入门 编写一个jQuery插件开始于给...
最近项目中需要实现3D图片层叠旋转木马切换的效果,于是用到了jquery.roundabout.js。 兼容性如图: ht...
一、什么是deferred对象? 开发网站的过程中,我们经常遇到某些耗时很长的javascript操作。其中,既有异...
AMD 模块 AMD(异步模块定义,Asynchronous Module Definition)格式总体的目标是为现在的开发者提供一...