jQuery增加和刪除表格項目及實現(xiàn)表格項目排序的方法
增加和刪除行
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之間數(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); }
表格排序
這個就稍微復雜點了...
主要思路:
因為JS有SORT的方法,對數(shù)組進行排序,那么通過個方法,我們就會想到數(shù)組了。
1.點標表格標頭的時候,取出點擊的是那一列。即列的索引值。因為下面要進行排序的就是該列。所以我要知道是點的那一列。
2.對表格的數(shù)據(jù)部分,也就是tbody部分,進行點擊的列的取值,把這些值存入到一個數(shù)組當中。
3.將存入數(shù)據(jù)的數(shù)組,通過SORT方法進行排序。(這里寫了兩種,升,或降,因為是點擊時要切換排序的方式。第一次降,第二次升,第三降,第四升,依次進行)
4.將排序好的數(shù)組的值進行遍歷,在遍歷過程中,和每一行TR的點擊列的那個TD當中的數(shù)據(jù)進行一個比較。如果相等,就插入到tbody的最后去.(最先插入的,將是在第一行。)
$(function(){ //存入點擊列的每一個TD的內(nèi)容; 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)); } }); } } //比較函數(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ù)組,取出前二個TD值; var fSetTdCont = function(thIndex){ $("tbody tr").each(function() { var tdCont = $(this).children("td:eq("+thIndex+")").text(); aTdCont.push(tdCont); }); } //點擊時需要執(zhí)行的函數(shù) var clickFun = function(thindex){ aTdCont = []; //獲取點擊當前列的索引值 var nThCount = thindex; //調(diào)用sortTh函數(shù) 取出要比較的數(shù)據(jù) fSetTdCont(nThCount); } //點擊事件綁定函數(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">價格</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>
效果:
- jquery獲取元素索引值index()示例
- jquery 獲取當前元素的索引值
- jQuery實現(xiàn)select下拉框獲取當前選中文本、值、索引
- jQuery實現(xiàn)獲取元素索引值index的方法
- jquery獲取當前元素索引值用法實例
- jQuery Jsonp跨域模擬搜索引擎
- jQuery表格排序組件-tablesorter使用示例
- jquery tablesorter.js 支持中文表格排序改進
- jquery.tableSort.js表格排序插件使用方法詳解
- 擴展jquery實現(xiàn)客戶端表格的分頁、排序功能代碼
- jQuery實現(xiàn)帶右側(cè)索引功能的通訊錄示例【附源碼下載】
相關(guān)文章
jQuery源碼分析-03構(gòu)造jQuery對象-源碼結(jié)構(gòu)和核心函數(shù)
jQuery源碼分析-03構(gòu)造jQuery對象-源碼結(jié)構(gòu)和核心函數(shù),需要的朋友可以參考下。2011-11-11把html頁面的部分內(nèi)容保存成新的html文件的jquery代碼
把html頁面的部分內(nèi)容保存成新的html文件,用到了jquery的獲取指定id的內(nèi)容。然后保存代碼。2009-11-11jQuery實現(xiàn)將頁面上HTML標簽換成另外標簽的方法
這篇文章主要介紹了jQuery實現(xiàn)將頁面上HTML標簽換成另外標簽的方法,實例說明了兩種實現(xiàn)html頁面元素替換的技巧,需要的朋友可以參考下2015-06-06ui組件之input多選下拉實現(xiàn)方法(帶有搜索功能)
這篇文章主要介紹了ui組件之input多選下拉實現(xiàn)方法(帶有搜索功能)的相關(guān)資料,需要的朋友可以參考下2016-07-07