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

分享一下代碼吧!
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);
}
表格排序
這個就稍微復(fù)雜點(diǎn)了...
主要思路:
因?yàn)镴S有SORT的方法,對數(shù)組進(jìn)行排序,那么通過個方法,我們就會想到數(shù)組了。
1.點(diǎn)標(biāo)表格標(biāo)頭的時候,取出點(diǎn)擊的是那一列。即列的索引值。因?yàn)橄旅嬉M(jìn)行排序的就是該列。所以我要知道是點(diǎn)的那一列。
2.對表格的數(shù)據(jù)部分,也就是tbody部分,進(jìn)行點(diǎn)擊的列的取值,把這些值存入到一個數(shù)組當(dāng)中。
3.將存入數(shù)據(jù)的數(shù)組,通過SORT方法進(jìn)行排序。(這里寫了兩種,升,或降,因?yàn)槭屈c(diǎn)擊時要切換排序的方式。第一次降,第二次升,第三降,第四升,依次進(jìn)行)
4.將排序好的數(shù)組的值進(jìn)行遍歷,在遍歷過程中,和每一行TR的點(diǎn)擊列的那個TD當(dāng)中的數(shù)據(jù)進(jìn)行一個比較。如果相等,就插入到tbody的最后去.(最先插入的,將是在第一行。)
$(function(){
//存入點(diǎn)擊列的每一個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ù)組,取出前二個TD值;
var fSetTdCont = function(thIndex){
$("tbody tr").each(function() {
var tdCont = $(this).children("td:eq("+thIndex+")").text();
aTdCont.push(tdCont);
});
}
//點(diǎn)擊時需要執(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">價格</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 獲取當(dāng)前元素的索引值
- jQuery實(shí)現(xiàn)select下拉框獲取當(dāng)前選中文本、值、索引
- jQuery實(shí)現(xiàn)獲取元素索引值index的方法
- jquery獲取當(dāng)前元素索引值用法實(shí)例
- jQuery Jsonp跨域模擬搜索引擎
- jQuery表格排序組件-tablesorter使用示例
- jquery tablesorter.js 支持中文表格排序改進(jìn)
- jquery.tableSort.js表格排序插件使用方法詳解
- 擴(kuò)展jquery實(shí)現(xiàn)客戶端表格的分頁、排序功能代碼
- jQuery實(shí)現(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-11
jQuery實(shí)現(xiàn)將頁面上HTML標(biāo)簽換成另外標(biāo)簽的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)將頁面上HTML標(biāo)簽換成另外標(biāo)簽的方法,實(shí)例說明了兩種實(shí)現(xiàn)html頁面元素替換的技巧,需要的朋友可以參考下2015-06-06
ui組件之input多選下拉實(shí)現(xiàn)方法(帶有搜索功能)
這篇文章主要介紹了ui組件之input多選下拉實(shí)現(xiàn)方法(帶有搜索功能)的相關(guān)資料,需要的朋友可以參考下2016-07-07
基于jQuery實(shí)現(xiàn)最基本的淡入淡出效果實(shí)例
這篇文章主要介紹了基于jQuery實(shí)現(xiàn)最基本的淡入淡出效果的方法,實(shí)例分析了jQuery中hide、show、toggle等函數(shù)的使用技巧,需要的朋友可以參考下2015-02-02
jQuery與getJson結(jié)合的用法實(shí)例
這篇文章主要介紹了jQuery與getJson結(jié)合的用法,實(shí)例分析了jquery解析json數(shù)據(jù)及數(shù)組遍歷的相關(guān)操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-08-08

