900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > JQuery实现表格中相同单元格合并示例代码【jquery】

JQuery实现表格中相同单元格合并示例代码【jquery】

时间:2022-05-08 10:12:30

相关推荐

JQuery实现表格中相同单元格合并示例代码【jquery】

web前端|js教程

JQuery,表格,单元格合并

web前端-js教程

代码:

php网站直播间源码,vscode插件不能启用,ubuntu 安装 sz,tomcat8889端口,用sqlite怎样确认输入,微信发爬虫是什么意思,php cgi 程序,镇江seo推广公司费用,金融企业类网站模板免费下载,登录 好看模板lzw

merge.html

function merge1(){ //可实现单元格,通过给 开始cell的比较

var totalRow = $("#tbl").find("tr").length;

var totalCol = $("#tbl").find("tr").eq(0).find("td").length;

for(var col=totalCol-1;col>=1;col--){

spanNum =1;

startCell = $("#tbl").find("tr").eq(totalRow-1).find("td").eq(col);

for(var row = totalRow-1;row>=1;row--){

targetCell = $("#tbl").find("tr").eq(row-1).find("td").eq(col);

if(startCell.text() == targetCell.text() && startCell.text()!=""){

spanNum++;

targetCell.attr("rowSpan",spanNum);

startCell.remove();

}else{

spanNum =1;

}

startCell = targetCell;

}

}

}

function merge2() { //可实现合并单元格,上下行来比较

var totalCols = $("#tbl").find("tr:eq(0)").find("td").length;

var totalRows = $("#tbl").find("tr").length;

for ( var i = totalCols-1; i >= 1; i--) {

for ( var j = totalRows-1; j >= 1; j--) {

startCell = $("#tbl").find("tr").eq(j).find("td").eq(i);

targetCell = $("#tbl").find("tr").eq(j - 1).find("td").eq(i);

if (startCell.text() == targetCell.text() && targetCell.text() != "") {

targetCell.attr("rowSpan", (startCell.attr("rowSpan")==undefined)?2:(eval(startCell.attr("rowSpan"))+1));

startCell.remove();

}

}

}

}

/*先合并,使用style 的display:none将相同元素隐藏,然后再remove

*/

function merge3(){

var totalCols = $("#tbl").find("tr:eq(0)").find("td").length;

var totalRows = $("#tbl").find("tr").length;

for(var col=totalCols-1;col>=1;col--){

spanNum =1;

startCell = $("#tbl").find("tr").eq(totalRows-1).find("td").eq(col);

for(var row = totalRows-1;row>=1;row--){

targetCell = $("#tbl").find("tr").eq(row-1).find("td").eq(col);

if(startCell.text() == targetCell.text() && startCell.text()!=""){

spanNum++;

targetCell.attr("rowSpan",spanNum);

startCell.attr("style","visibility:hidden");

// startCell.attr("style","display:none");

}else{

spanNum =1;

}

startCell = targetCell;

}

}

for(var j=totalCols-1;j>=1;j--){

for(var i=totalRows-1;i>=1;i--){

cell = $("#tbl").find("tr").eq(i).find("td").eq(j);

if(cell.attr("style")!=undefined){

if(cell.attr("style")=="visibility:hidden"){

cell.remove();

}

}

}

}

}

function merge4(){ //与merge3方法类似,目的是看一下 display:none与visibility:hidden的效果区别

var totalCols = $("#tbl").find("tr:eq(0)").find("td").length;

var totalRows = $("#tbl").find("tr").length;

for(var col=totalCols-1;col>=1;col--){

spanNum =1;

startCell = $("#tbl").find("tr").eq(totalRows-1).find("td").eq(col);

for(var row = totalRows-1;row>=1;row--){

targetCell = $("#tbl").find("tr").eq(row-1).find("td").eq(col);

if(startCell.text() == targetCell.text() && startCell.text()!=""){

spanNum++;

targetCell.attr("rowSpan",spanNum);

startCell.attr("style","display:none");

// startCell.attr("style","display:none");

}else{

spanNum =1;

}

startCell = targetCell;

}

}

for(var j=totalCols-1;j>=1;j--){

for(var i=totalRows-1;i>=1;i--){

cell = $("#tbl").find("tr").eq(i).find("td").eq(j);

if(cell.attr("style")!=undefined){

if(cell.attr("style")=="display:none"){

cell.remove();

}

}

}

}

}

总结:在使用remove的时候,一定要注意如果 从list的开始元素循环下去,remove掉一个元素后,有些元素就找不到了或者说不是要找的那个元素;最好是从后面开始循环。

进销存网页版源码,vscode配置 c,ubuntu撤销,nmap识别tomcat,sqlite 数据库 源码,WordPress插件降级,适合很多表格的前端框架,厕所常见的黑色爬虫图片,php 手机 app,站内seo优化检测,cms网站淘客,网页表单 源码,商业广告模板免费下载lzw

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。