jquery操作表格 合并单元格

jquery操作table,合并单元格,合并相同的行

 

合并的方法

$("#tableid").mergeCell({
  cols:[X,X] ///参数为要合并的列
})
 /**
 * 操作表格 合并单元格 行
 * 2016年12月13日16:00:41
    
 */
(function($) {
    // 看过jquery源码就可以发现$.fn就是$.prototype, 只是为了兼容早期版本的插件
    // 才保留了jQuery.prototype这个形式
    $.fn.mergeCell = function(options) {
        return this.each(function() {
            var cols = options.cols;
            for ( var i = cols.length - 1; cols[i] != undefined; i--) {
              // fixbug console调试
              // console.debug(cols[i]);
              mergeCell($(this), cols[i]);
            }
            dispose($(this));
        });
    };
    // 如果对javascript的closure和scope概念比较清楚, 这是个插件内部使用的private方法
    // 具体可以参考本人前一篇随笔里介绍的那本书
    function mergeCell($table, colIndex) {
  
        $table.data('col-content', ''); // 存放单元格内容
        $table.data('col-rowspan', 1);  // 存放计算的rowspan值  默认为1
        $table.data('col-td', $());     // 存放发现的第一个与前一行比较结果不同td(jQuery封装过的), 默认一个"空"的jquery对象
        $table.data('trNum', $('tbody tr', $table).length); // 要处理表格的总行数, 用于最后一行做特殊处理时进行判断之用
          
        // 我们对每一行数据进行"扫面"处理 关键是定位col-td, 和其对应的rowspan
        $('tbody tr', $table).each(function(index) {
            // td:eq中的colIndex即列索引
            var $td = $('td:eq(' + colIndex + ')', this);
  
            // 取出单元格的当前内容
            var currentContent = $td.html();
  
            // 第一次时走此分支
            if ($table.data('col-content') == '') {
  
                $table.data('col-content', currentContent);
                $table.data('col-td', $td);
  
            } else {
                // 上一行与当前行内容相同
                if ($table.data('col-content') == currentContent) {
                    // 上一行与当前行内容相同则col-rowspan累加, 保存新值
                    var rowspan = $table.data('col-rowspan') + 1;
                    $table.data('col-rowspan', rowspan);
                    // 值得注意的是  如果用了$td.remove()就会对其他列的处理造成影响
                    $td.hide();
  
                    // 最后一行的情况比较特殊一点
                    // 比如最后2行 td中的内容是一样的, 那么到最后一行就应该把此时的col-td里保存的td设置rowspan
                    if (++index == $table.data('trNum'))
                        $table.data('col-td').attr('rowspan', $table.data('col-rowspan'));
              
                } else { // 上一行与当前行内容不同
                    // col-rowspan默认为1, 如果统计出的col-rowspan没有变化, 不处理
                    if ($table.data('col-rowspan') != 1) {
                        $table.data('col-td').attr('rowspan', $table.data('col-rowspan'));
                    }
                    // 保存第一次出现不同内容的td, 和其内容, 重置col-rowspan
                    $table.data('col-td', $td);
                    $table.data('col-content', $td.html());
                    $table.data('col-rowspan', 1);
                }
            }
        });
    }
      
    // 同样是个private函数  清理内存之用
    function dispose($table) {
        $table.removeData();
    }
})(jQuery);

 示例html代码


<
html> <head> <script type="text/javascript" src="jquery-1.7.1.min.js"></script> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>酒店分房表</title> <style mce_bogus="1" type="text/css"> html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, caption, tfoot, thead, th, s { margin:0; padding:0; border:0; font-size:100%; vertical-align:baseline; font-style:normal; text-decoration:none;word-wrap: break-word;} body {font-family: SimSun; font-style:italic; font-weight:bold; font-size:12px; background:none;margin-left: auto;margin-right: auto;} a { color:#000000; font-size:14px;line-height:26px; font-family:SimSun; text-decoration:none; } a:hover { color:#000000; font-size:14px; line-height:26px; font-family:SimSun; text-decoration:none;} .bt{color: #121212;font-size: 26px; line-height:80px;text-align: center;} .A4 { margin:auto;width: 780px;} .title { color: #0070C0; } </style> </head> <body> <div class="A4"> <br/><br/> <div align="center"> <h1><strong style="font-size: 24;">酒店信息和分房表</strong></h1> <br/><br/> </div> <table width="780" border="1" cellspacing="0" cellpadding="20" style="table-layout:fixed; word-break:break-strict;repeat-header:yes;repeat-footer:yes;"> <tr> <td width="140" align="center"><b>居住城市</b></td> <td width="120" align="center"><b>入住日期</b></td> <td width="120" align="center"><b>离店日期</b></td> <td width="200" align="center"><b>酒店名称</b></td> <td width="200" align="center"><b>地址</b></td> </tr> <tbody> <tr> <td align="center"></td> <td align="center">2016-12-11</td> <td align="center"> 2016-12-12</td> <td align="center"> 性格里拉</td> <td align="center"> 上海</td> </tr> </tbody> </table> <br/><br/> <table width="780" border="1" cellspacing="0" cellpadding="20" style="table-layout:fixed; word-break:break-strict;repeat-header:yes;repeat-footer:yes;"> <tr> <td width="140" align="center"><b>房间类型</b></td> <td width="120" align="center"><b>双床房</b></td> </tr> <tbody> <tr> <td align="center"><b>数量共计: 5 间</b></td> <td align="center">5</td> </tr> </tbody> </table> <br/><br/> <table id="table_4" width="780" border="1" cellspacing="0" cellpadding="0" style="table-layout:fixed; word-break:break-strict;repeat-header:yes;repeat-footer:yes;"> <tr> <td width="50" align="center"><b>Room</b></td> <td width="50" align="center"><b>Adult</b></td> <td width="120" align="center"><b>中文名</b></td> <td width="200" align="center"><b>Name</b></td> <td width="50" align="center"><b>Sex</b></td> <td width="200" align="center"><b>Room Type</b></td> </tr> <tr> <td align="center">1</td> <td align="center">1</td> <td align="center"> 熊哥1</td> <td align="center"> xsw </td> <td align="center"></td> <td align="center"> 双床房1</td> </tr> <tr> <td align="center">1</td> <td align="center">2</td> <td align="center"> 熊哥2</td> <td align="center"> xsw2222222 </td> <td align="center"></td> <td align="center"> 双床房1</td> </tr> <tr> <td align="center">1</td> <td align="center">3</td> <td align="center"> 杰森.斯坦森</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房1</td> </tr> <tr> <td align="center">2</td> <td align="center">4</td> <td align="center"> 李锡龄</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房2</td> </tr> <tr> <td align="center">2</td> <td align="center">5</td> <td align="center"> 李孝利</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房2</td> </tr> <tr> <td align="center">2</td> <td align="center">6</td> <td align="center"> 刘德国</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房2</td> </tr> <tr> <td align="center">3</td> <td align="center">7</td> <td align="center"> 杰森.四米</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房3</td> </tr> <tr> <td align="center">3</td> <td align="center">8</td> <td align="center"> 凯威.斯坦森</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房3</td> </tr> <tr> <td align="center">3</td> <td align="center">9</td> <td align="center"> 杰森史蒂文</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房3</td> </tr> <tr> <td align="center">4</td> <td align="center">10</td> <td align="center"> 5</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房4</td> </tr> <tr> <td align="center">4</td> <td align="center">11</td> <td align="center"> 3</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房4</td> </tr> <tr> <td align="center">4</td> <td align="center">12</td> <td align="center"> 1</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房4</td> </tr> <tr> <td align="center">4</td> <td align="center">13</td> <td align="center"> 杰森.托马鞍山</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房4</td> </tr> <tr> <td align="center">5</td> <td align="center">14</td> <td align="center"> 孙露</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房5</td> </tr> <tr> <td align="center">5</td> <td align="center">15</td> <td align="center"> 李红梅</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房5</td> </tr> <tr> <td align="center">5</td> <td align="center">16</td> <td align="center"> 卓越杀</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房5</td> </tr> <tr> <td align="center">5</td> <td align="center">17</td> <td align="center"> 4</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房5</td> </tr> <tr> <td align="center">5</td> <td align="center">18</td> <td align="center"> 12</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房5</td> </tr> <tr> <td align="center">5</td> <td align="center">19</td> <td align="center"> 16</td> <td align="center"> Jason Statham</td> <td align="center"></td> <td align="center"> 双床房5</td> </tr> </table> <br/><br/> </div> </body> <script type="text/javascript"> /** * 操作表格 合并单元格 行 * 2016年12月13日16:00:41 */ (function($) { // 看过jquery源码就可以发现$.fn就是$.prototype, 只是为了兼容早期版本的插件 // 才保留了jQuery.prototype这个形式 $.fn.mergeCell = function(options) { return this.each(function() { var cols = options.cols; for ( var i = cols.length - 1; cols[i] != undefined; i--) { // fixbug console调试 // console.debug(cols[i]); mergeCell($(this), cols[i]); } dispose($(this)); }); }; // 如果对javascript的closure和scope概念比较清楚, 这是个插件内部使用的private方法 // 具体可以参考本人前一篇随笔里介绍的那本书 function mergeCell($table, colIndex) { $table.data('col-content', ''); // 存放单元格内容 $table.data('col-rowspan', 1); // 存放计算的rowspan值 默认为1 $table.data('col-td', $()); // 存放发现的第一个与前一行比较结果不同td(jQuery封装过的), 默认一个"空"的jquery对象 $table.data('trNum', $('tbody tr', $table).length); // 要处理表格的总行数, 用于最后一行做特殊处理时进行判断之用 // 我们对每一行数据进行"扫面"处理 关键是定位col-td, 和其对应的rowspan $('tbody tr', $table).each(function(index) { // td:eq中的colIndex即列索引 var $td = $('td:eq(' + colIndex + ')', this); // 取出单元格的当前内容 var currentContent = $td.html(); // 第一次时走此分支 if ($table.data('col-content') == '') { $table.data('col-content', currentContent); $table.data('col-td', $td); } else { // 上一行与当前行内容相同 if ($table.data('col-content') == currentContent) { // 上一行与当前行内容相同则col-rowspan累加, 保存新值 var rowspan = $table.data('col-rowspan') + 1; $table.data('col-rowspan', rowspan); // 值得注意的是 如果用了$td.remove()就会对其他列的处理造成影响 $td.hide(); // 最后一行的情况比较特殊一点 // 比如最后2行 td中的内容是一样的, 那么到最后一行就应该把此时的col-td里保存的td设置rowspan if (++index == $table.data('trNum')) $table.data('col-td').attr('rowspan', $table.data('col-rowspan')); } else { // 上一行与当前行内容不同 // col-rowspan默认为1, 如果统计出的col-rowspan没有变化, 不处理 if ($table.data('col-rowspan') != 1) { $table.data('col-td').attr('rowspan', $table.data('col-rowspan')); } // 保存第一次出现不同内容的td, 和其内容, 重置col-rowspan $table.data('col-td', $td); $table.data('col-content', $td.html()); $table.data('col-rowspan', 1); } } }); } // 同样是个private函数 清理内存之用 function dispose($table) { $table.removeData(); } })(jQuery); $('#table_4').mergeCell({ cols:[0,5] }); </script> </html>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
layui是一款基于jQuery的前端UI框架,它提供了丰富的组件和样式,方便开发者快速构建美观的网页界面。在layui中,合并单元格是通过表格组件来实现的。 要实现layui中的合并单元格功能,可以使用layui的表格组件,并结合一些自定义的方法来实现。下面是一个简单的示例代码: ```html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>layui合并单元格示例</title> <link rel="stylesheet" href="https://cdn.staticfile.org/layui/2.5.6/css/layui.css"> </head> <body> <table class="layui-table" lay-skin="line"> <colgroup> <col width="150"> <col width="200"> <col> </colgroup> <thead> <tr> <th>姓名</th> <th>城市</th> <th>职业</th> </tr> </thead> <tbody> <tr> <td rowspan="2">张三</td> <td>北京</td> <td>工程师</td> </tr> <tr> <td>上海</td> <td>设计师</td> </tr> <tr> <td>李四</td> <td>广州</td> <td>销售员</td> </tr> </tbody> </table> <script src="https://cdn.staticfile.org/jquery/3.4.1/jquery.min.js"></script> <script src="https://cdn.staticfile.org/layui/2.5.6/layui.js"></script> <script> layui.use('table', function(){ var table = layui.table; // 执行合并单元格的方法 table.on('renderComplete', function(res){ mergeCells(res); }); // 合并单元格的方法 function mergeCells(res) { var data = res.data; var mergeIndex = 0; var mergeCount = 1; for (var i = 1; i < data.length; i++) { if (data[i].name === data[mergeIndex].name) { mergeCount++; if (i === data.length - 1) { merge(res, mergeIndex, mergeCount); } } else { merge(res, mergeIndex, mergeCount); mergeIndex = i; mergeCount = 1; } } } // 执行合并单元格操作 function merge(res, mergeIndex, mergeCount) { var tableId = res.config.id; var $table = $('#' + tableId); $table.find('tr').eq(mergeIndex).find('td').eq(0).attr('rowspan', mergeCount); for (var i = mergeIndex + 1; i < mergeIndex + mergeCount; i++) { $table.find('tr').eq(i).find('td').eq(0).remove(); } } // 渲染表格 table.render({ elem: '.layui-table', done: function(res, curr, count){ table.emit('renderComplete', res); } }); }); </script> </body> </html> ``` 在上面的示例代码中,我们使用了layui的表格组件,并通过设置`rowspan`属性来实现单元格的合并。通过自定义的`mergeCells`方法,可以实现对表格数据的遍历和合并操作

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

熊哥club

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值