增加和删除行
jquery对表格的操作是老生常谈的问题。最近项目中用到了,今天在这里分享一下!
效果大体如下:
分享一下代码吧!
html
<div class="table-responsive" id="Bk_table" style="display:none;"> <table class="table table-hover table-bordered"> <thead> <tr> <th> <div class="out"> <b>板块</b> <em>维度</em> </div> </th> </tr> </thead> <tbody> </tbody> </table> </div>
js操作如下:
deleteLie: function () { //删除一列 var index = $(this).parent().index(); for (var i = 0; i < $(".table tr").length; i++) { $($(".table tr")[i]).children().eq(index).remove(); } if ($(".table tr").length == 1 && $(".table tr").eq(0).children().length == 1) { $("#Bk_table").hide(); $(".blankShow").show(); } }, deleteOneline: function () { //删除一行 $(this).parent().parent().remove(); if ($(".table tr").length == 1 && $(".table tr").eq(0).children().length == 1) { $("#Bk_table").hide(); $(".blankShow").show(); } }, addOneBk: function () { //增加一列 if ($("#Bk_table").is(":hidden")) { $("#Bk_table").show(); } if ($(".blankShow").is(":visible")) { $(".blankShow").hide(); } var firstLie = ' <th class="hovershow"><span class="font_zs" style="display:none">中弘西岸3</span>' + '<input type="text" class="form-control getPrevalue" placeholder="填写板块名称" />' + '<a class="glyphicon glyphicon-remove bkdelete delete_lie"></a></th>'; $(".table>thead>tr").eq(0).append(firstLie); var otherLie = '<td><input type="text" class="form-control" value="" placeholder="1-5之间数字" ' + 'onkeyup="if(isNaN(value)||parseFloat(value)>5||parseFloat(value)<1)execCommand(\'undo\')"' + 'onafterpaste="if(isNaN(value)||parseFloat(value)>5||parseFloat(value)<1)execCommand(\'undo\')" /></td>'; $(".table>tbody>tr").append(otherLie); }, addWd: function () { //增加一行 if ($("#Bk_table").is(":hidden")) { $("#Bk_table").show(); } if ($(".blankShow").is(":visible")) { $(".blankShow").hide(); } var Wdhtml_1 = '<tr>' + ' <th scope="row" class="hovershow">' + '<span class="font_zs t1" style="display:none">维度三</span>' + '<input type="text" class="form-control getPrevalue" placeholder="填写维度名称" />' + '<a class="glyphicon glyphicon-remove bkdelete deleteoneline"></a>' + '</th>'; var Wdhtml_2 = ""; var LieLength = $(".table>thead>tr").children().length - 1; if (LieLength > 0) { for (var i = 0; i < LieLength; i++) { Wdhtml_2 = Wdhtml_2 + ' <td><input type="text" class="form-control" value="" placeholder="1-5之间数字" onkeyup="if(isNaN(value)||parseFloat(value)>5||parseFloat(value)<1)execCommand(\'undo\')" onafterpaste="if(isNaN(value)||parseFloat(value)>5||parseFloat(value)<1)execCommand(\'undo\')" /></td>'; } } var Wdhtml_3 = '</tr>'; var allWd = Wdhtml_1 + Wdhtml_2 + Wdhtml_3; $(".table>tbody").append(allWd); }
表格排序
这个就稍微复杂点了...
主要思路:
因为JS有SORT的方法,对数组进行排序,那么通过个方法,我们就会想到数组了。
1.点标表格标头的时候,取出点击的是那一列。即列的索引值。因为下面要进行排序的就是该列。所以我要知道是点的那一列。
2.对表格的数据部分,也就是tbody部分,进行点击的列的取值,把这些值存入到一个数组当中。
3.将存入数据的数组,通过SORT方法进行排序。(这里写了两种,升,或降,因为是点击时要切换排序的方式。第一次降,第二次升,第三降,第四升,依次进行)
4.将排序好的数组的值进行遍历,在遍历过程中,和每一行TR的点击列的那个TD当中的数据进行一个比较。如果相等,就插入到tbody的最后去.(最先插入的,将是在第一行。)
$(function(){ //存入点击列的每一个TD的内容; var aTdCont = []; //点击列的索引值 var thi = 0 //重新对TR进行排序 var setTrIndex = function(tdIndex){ for(i=0;i<aTdCont.length;i++){ var trCont = aTdCont[i]; $("tbody tr").each(function() { var thisText = $(this).children("td:eq("+tdIndex+")").text(); if(thisText == trCont){ $("tbody").append($(this)); } }); } } //比较函数的参数函数 var compare_down = function(a,b){ return a-b; } var compare_up = function(a,b){ return b-a; } //比较函数 var fSort = function(compare){ aTdCont.sort(compare); } //取出TD的值,并存入数组,取出前二个TD值; var fSetTdCont = function(thIndex){ $("tbody tr").each(function() { var tdCont = $(this).children("td:eq("+thIndex+")").text(); aTdCont.push(tdCont); }); } //点击时需要执行的函数 var clickFun = function(thindex){ aTdCont = []; //获取点击当前列的索引值 var nThCount = thindex; //调用sortTh函数 取出要比较的数据 fSetTdCont(nThCount); } //点击事件绑定函数 $("th").toggle(function(){ thi= $(this).index(); clickFun(thi); //调用比较函数,降序 fSort(compare_up); //重新排序行 setTrIndex(thi); },function(){ clickFun(thi); //调用比较函数 升序 fSort(compare_down); //重新排序行 setTrIndex(thi); }) })
示例:
<style type="text/css"> *{ margin:0px; padding:0px;} table{ border-collapse:collapse;} table td{ border:1px solid #036; text-align:center; } thead tr th{ cursor:pointer; background:#066; color:#FFFFFF; } thead tr th:hover{ background:#369;} </style> <table class="tabSort" width="546" height="300" border="0" align="center" cellpadding="0" cellspacing="0"> <thead> <tr> <th scope="col">名称</th> <th scope="col">价格</th> <th scope="col">地址</th> <th scope="col">备注</th> <th scope="col">时间</th> </tr> </thead> <tbody> <tr> <td>商品1</td> <td>10.5</td> <td> </td> <td> </td> <td> </td> </tr> <tr> <td>商品2</td> <td>11.3</td> <td> </td> <td> </td> <td> </td> </tr> <tr> <td>商品3</td> <td>9.8</td> <td> </td> <td> </td> <td> </td> </tr> <tr> <td>商品4</td> <td>12.6</td> <td> </td> <td> </td> <td> </td> </tr> <tr> <td>商品5</td> <td>13.9</td> <td> </td> <td> </td> <td> </td> </tr> <tr> <td>商品6</td> <td>18</td> <td> </td> <td> </td> <td> </td> </tr> <tr> <td>商品7</td> <td>21.3</td> <td> </td> <td> </td> <td> </td> </tr> <tr> <td>商品8</td> <td>6.5</td> <td> </td> <td> </td> <td> </td> </tr> <tr> <td>商品9</td> <td>7.4</td> <td> </td> <td> </td> <td> </td> </tr> </tbody> </table>
效果:
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月30日
2024年11月30日
- 群星《人声1号[十大发烧情歌]》2CD[WAV分轨]
- 《郁可唯所有歌曲合集》[FLAC/MP3][6.2G]
- 郑秀文《SOUND OF MI》2024 7月新专辑[FLAC/MP3][1.1G]
- 费玉清《费玉清精粹》[FLAC][1G]
- 黑豹乐队-至爱极品顶级享受《豹行天下3CD》[WAV分轨]
- 音响系统测试碟《AbsoluteSamplerOnTheFly》[WAV+CUE]
- 一流的爵士乐《FirstClassJazz》ArtBlakey[正版原抓WAV+CUE]
- 杨千嬅《狼来了》[DSF][1.2G]
- 车载《旧情绵绵一路伴随》80后经典[FLAC/MP3][1G]
- 刀郎《身披彩衣的姑娘》[FLAC][1.4G]
- 张国荣《MissYouMix》美压版[正版原抓WAV+CUE]
- 长笛和吉他的浪漫音乐《OriginalRomanticMusicforFluteandGuitar》[WAV+CUE]
- 窦唯《八段锦》(上海音像)[WAV+CUE]
- DJ动力100%《堵在路上的解闷high曲》[FLAC/MP3][948M]
- 节奏炸裂《抖音最嗨 DJ 舞曲大合集》[FLAC/MP3][2G]