国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jQuery增加和刪除表格項(xiàng)目及實(shí)現(xiàn)表格項(xiàng)目排序的方法

2019-11-20 09:51:04
字體:
供稿:網(wǎng)友

增加和刪除行
jquery對表格的操作是老生常談的問題。最近項(xiàng)目中用到了,今天在這里分享一下!
效果大體如下:

2016530164711889.gif (712×315)

分享一下代碼吧!
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之間數(shù)字" ' +          '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之間數(shù)字" 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);}

表格排序
這個(gè)就稍微復(fù)雜點(diǎn)了...
主要思路:
因?yàn)镴S有SORT的方法,對數(shù)組進(jìn)行排序,那么通過個(gè)方法,我們就會(huì)想到數(shù)組了。
1.點(diǎn)標(biāo)表格標(biāo)頭的時(shí)候,取出點(diǎn)擊的是那一列。即列的索引值。因?yàn)橄旅嬉M(jìn)行排序的就是該列。所以我要知道是點(diǎn)的那一列。
2.對表格的數(shù)據(jù)部分,也就是tbody部分,進(jìn)行點(diǎn)擊的列的取值,把這些值存入到一個(gè)數(shù)組當(dāng)中。
3.將存入數(shù)據(jù)的數(shù)組,通過SORT方法進(jìn)行排序。(這里寫了兩種,升,或降,因?yàn)槭屈c(diǎn)擊時(shí)要切換排序的方式。第一次降,第二次升,第三降,第四升,依次進(jìn)行)
4.將排序好的數(shù)組的值進(jìn)行遍歷,在遍歷過程中,和每一行TR的點(diǎn)擊列的那個(gè)TD當(dāng)中的數(shù)據(jù)進(jìn)行一個(gè)比較。如果相等,就插入到tbody的最后去.(最先插入的,將是在第一行。)

$(function(){  //存入點(diǎn)擊列的每一個(gè)TD的內(nèi)容;  var aTdCont = [];  //點(diǎn)擊列的索引值  var thi = 0    //重新對TR進(jìn)行排序  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));        }       });        }  }    //比較函數(shù)的參數(shù)函數(shù)  var compare_down = function(a,b){      return a-b;  }    var compare_up = function(a,b){      return b-a;  }    //比較函數(shù)  var fSort = function(compare){    aTdCont.sort(compare);  }    //取出TD的值,并存入數(shù)組,取出前二個(gè)TD值;  var fSetTdCont = function(thIndex){      $("tbody tr").each(function() {        var tdCont = $(this).children("td:eq("+thIndex+")").text();        aTdCont.push(tdCont);      });  }  //點(diǎn)擊時(shí)需要執(zhí)行的函數(shù)  var clickFun = function(thindex){    aTdCont = [];    //獲取點(diǎn)擊當(dāng)前列的索引值    var nThCount = thindex;    //調(diào)用sortTh函數(shù) 取出要比較的數(shù)據(jù)    fSetTdCont(nThCount);  }    //點(diǎn)擊事件綁定函數(shù)  $("th").toggle(function(){    thi= $(this).index();    clickFun(thi);    //調(diào)用比較函數(shù),降序    fSort(compare_up);    //重新排序行    setTrIndex(thi);  },function(){    clickFun(thi);    //調(diào)用比較函數(shù) 升序    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">價(jià)格</th>   <th scope="col">地址</th>   <th scope="col">備注</th>   <th scope="col">時(shí)間</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>

效果:

2016530164848909.png (547×303)

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 康定县| 福州市| 嵊泗县| 确山县| 沂源县| 崇信县| 莱芜市| 张家港市| 文山县| 始兴县| 固安县| 松阳县| 汉寿县| 香港| 辛集市| 万安县| 金川县| 开封县| 黑河市| 沙湾县| 晋江市| 体育| 石城县| 渭南市| 高平市| 三河市| 孙吴县| 抚宁县| 山阴县| 英吉沙县| 二连浩特市| 秦皇岛市| 哈尔滨市| 樟树市| 密云县| 鲁甸县| 车致| 和顺县| 光山县| 烟台市| 三穗县|