亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

javascript-表格排序(降序/反序)實(shí)現(xiàn)介紹(附圖)

 更新時(shí)間:2013年05月30日 16:17:15   作者:  
使用了Array方法、sort:降序、reverse:反序完成了基本功能,對(duì)于聯(lián)合排序沒有實(shí)現(xiàn),感興趣的朋友可以參考下哈
知識(shí)點(diǎn):

Array方法:

sort:降序

reverse:反序

效果:
 
代碼:
復(fù)制代碼 代碼如下:

<style>
*{
margin: 0;
padding: 0;
}
#tableSort{
line-height: 22px;
background: #ccc;
}
#tableSort thead,
#tableSort tfoot{
background: #066;
color: #fff;
font-size: 14px;
}
#tableSort thead a,
#tableSort tfoot a{
color: #fff;
}
#tableSort tfoot{
background: #069;
}
#tableSort tbody td{
background: #fff;
padding: 3px 5px;
font-size: 12px;
}
</style>
<table width="500" border="0" cellspacing="1" cellpadding="0" id="tableSort">
<thead>
<tr>
<th width="31" align="center">&nbsp;</th>
<th width="104">商品名稱</th>
<th width="104">商品描述</th>
<th width="124" id="timeSort" _isDesc="false">上架時(shí)間</th>
<th width="82" id="priceSort" _isDesc="false">價(jià)格</th>
<th width="48">操作</th>
</tr>
</thead>
<tbody>
<tr>
<td align="center"><input type="checkbox" name="checkbox3" id="checkbox2" _op="check" /></td>
<td>1</td>
<td>12312312313</td>
<td>2013-5-8</td>
<td>¥120</td>
<td align="center"><a href="javascript:void(0)" _op="del">刪除</a></td>
</tr>
<tr>
<td align="center"><input type="checkbox" name="checkbox4" id="checkbox3" _op="check" /></td>
<td>2</td>
<td>頂戴</td>
<td>2013-5-12</td>
<td>¥140</td>
<td align="center"><a href="javascript:void(0)" _op="del">刪除</a></td>
</tr>
<tr>
<td align="center"><input type="checkbox" name="checkbox5" id="checkbox4" _op="check" /></td>
<td>3</td>
<td>欠工</td>
<td>2013-4-8</td>
<td>¥320</td>
<td align="center"><a href="javascript:void(0)" _op="del">刪除</a></td>
</tr>
<tr>
<td align="center"><input type="checkbox" name="checkbox6" id="checkbox5" _op="check" /></td>
<td>4</td>
<td>七七</td>
<td>2013-8-8</td>
<td>¥520</td>
<td align="center"><a href="javascript:void(0)" _op="del">刪除</a></td>
</tr>
<tr>
<td align="center"><input type="checkbox" name="checkbox7" id="checkbox6" _op="check" /></td>
<td>5</td>
<td>苛</td>
<td>2013-5-25</td>
<td>¥820</td>
<td align="center"><a href="javascript:void(0)" _op="del">刪除</a></td>
</tr>
<tr>
<td align="center"><input type="checkbox" name="checkbox8" id="checkbox7" _op="check" /></td>
<td>6</td>
<td>黃梅雨</td>
<td>2013-5-2</td>
<td>¥120</td>
<td align="center"><a href="javascript:void(0)" _op="del">刪除</a></td>
</tr>
<tr>
<td align="center"><input type="checkbox" name="checkbox9" id="checkbox8" _op="check" /></td>
<td>7</td>
<td>工作服</td>
<td>2013-5-18</td>
<td>¥1220</td>
<td align="center"><a href="javascript:void(0)" _op="del">刪除</a></td>
</tr>
<tr>
<td align="center"><input type="checkbox" name="checkbox10" id="checkbox9" _op="check" /></td>
<td>8</td>
<td>地茜共</td>
<td>2013-3-8</td>
<td>¥1260</td>
<td align="center"><a href="javascript:void(0)" _op="del">刪除</a></td>
</tr>
</tbody>
<tfoot>
<tr>
<th align="center"><input type="checkbox" name="checkbox" id="checkAll" /></th>
<th align="left"><a href="javascript:void(0)" id="reserveCheck" >反選</a>&nbsp;&nbsp;<a href="javascript:void(0)" id="delSelect">刪除</a></th>
<th align="left">&nbsp;</th>
<th>&nbsp;</th>
<th>&nbsp;</th>
<th><a href="#"></a></th>
</tr>
</tfoot>
</table>
<script>
//批量設(shè)置checked值
function setChecked(checkBoxs,checked){
for(var i=0,len=checkBoxs.length;i<len;i++){
checkBoxs[i].checked=checked;
}
}
//批量反置checked值
function reverseChecked(checkBoxs){
for(var i=0,len=checkBoxs.length;i<len;i++){
checkBoxs[i].checked=!checkBoxs[i].checked;
}
}
//移除tr值
function removeTr(tBody,tr){
tBody.removeChild(tr);
}
//獲取tr
function getParentTr(o){
while(o){
o=o.parentNode;
if(o&&o.tagName==="TR"){
return o;
}
}
}
//arrSort排序
function arrSort(arr,isDesc){
var arr=arr.sort(function(num1,num2){
return num1-num2;
});
if(isDesc){//desc
arr.reverse();
}
return arr;
}
//表格排序
function tableSort(tablePart,col,fun,isDesc){
var arrNum=[],trs={};

for(var i=0,len=tablePart.rows.length;i<len;i++){
var td=tablePart.rows[i].cells[col];
var num=fun(td);
arrNum.push(num);
trs["id"+num]=trs["id"+num]||[];
trs["id"+num].push(getParentTr(td));
}
arrNum=arrSort(arrNum,isDesc);
for(var j=0,jlen=arrNum.length;j<jlen;j++){
for(var k=0,klen=trs["id"+arrNum[j]].length;k<klen;k++){
var tr=trs["id"+arrNum[j]].pop();
tablePart.appendChild(tr);
}
}
}


var table=document.getElementById("tableSort");
var checkBoxs=table.tBodies[0].getElementsByTagName('input');
var checkAll=document.getElementById("checkAll");
var reserveCheck=document.getElementById("reserveCheck");
var delSelect=document.getElementById("delSelect");
var timeSort=document.getElementById("timeSort");
var priceSort=document.getElementById("priceSort");

checkAll.onclick=function(){
setChecked(checkBoxs,this.checked);
}

reserveCheck.onclick=function(){
reverseChecked(checkBoxs);
}
table.tBodies[0].onclick=function(e){
var ev=e||window.event;
var target=ev.target||ev.srcElement;
if(!target)return;
target._op=target.getAttribute("_op");
if(!target._op)return;

if(target._op==="check"&&target.type==="checkbox"&&!target.checked){
checkAll.checked=target.checked;
}
if(target._op==="del"){
var tr=getParentTr(target);
removeTr(table.tBodies[0],tr);
}
}
delSelect.onclick=function(){
var chk=[];
for(var i=0,len=checkBoxs.length;i<len;i++){
if(checkBoxs[i].checked){
var tr=getParentTr(checkBoxs[i]);
chk.push(tr);
}
}


for(var j=0,jlen=chk.length;j<jlen;j++){
removeTr(table.tBodies[0],chk[j]);
}
}
var sortMark="↑↓";
timeSort.onclick=function(){
this.isDesc=(this.isDesc===true)?false:true;
tableSort(table.tBodies[0],3,function(td){
return (new Date(td.innerHTML)).getTime();
},this.isDesc);
priceSort.innerHTML="價(jià)格"
this.innerHTML="上架時(shí)間"+sortMark[this.isDesc?1:0];
}
priceSort.onclick=function(){
this.isDesc=(this.isDesc===true)?false:true;
tableSort(table.tBodies[0],4,function(td){
return parseInt(td.innerHTML.replace("¥",''));
},this.isDesc);
timeSort.innerHTML="上架時(shí)間";
this.innerHTML="價(jià)格"+sortMark[this.isDesc?1:0];
}

</script>

總結(jié):

完成了基本功能,對(duì)于聯(lián)合排序沒有實(shí)現(xiàn)。后期會(huì)慢慢加入,有興趣的可以把代碼放到html頁面,運(yùn)行查看效果。

相關(guān)文章

  • javascript中的相等操作符(==與===區(qū)別)

    javascript中的相等操作符(==與===區(qū)別)

    這篇文章主要介紹了javascript中的相等操作符(==與===區(qū)別),需要的朋友可以參考下
    2019-12-12
  • JS如何實(shí)現(xiàn)Base64編碼和解碼(及中文亂碼問題)

    JS如何實(shí)現(xiàn)Base64編碼和解碼(及中文亂碼問題)

    這篇文章主要給大家介紹了關(guān)于JS如何實(shí)現(xiàn)Base64編碼和解碼及中文亂碼問題的相關(guān)資料,Base64編碼是一種常用的將二進(jìn)制數(shù)據(jù)轉(zhuǎn)換為文本數(shù)據(jù)的方式,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10
  • js實(shí)現(xiàn)select組件的選擇輸入過濾代碼

    js實(shí)現(xiàn)select組件的選擇輸入過濾代碼

    如何實(shí)現(xiàn)select組件的選擇輸入過濾作用,下面有一段js代碼,很實(shí)用,需要的朋友可以看看
    2014-10-10
  • 微信小程序模板和模塊化用法實(shí)例分析

    微信小程序模板和模塊化用法實(shí)例分析

    這篇文章主要介紹了微信小程序模板和模塊化用法,結(jié)合實(shí)例形式分析了微信小程序中的模板與模塊化概念與簡(jiǎn)單使用技巧,需要的朋友可以參考下
    2017-11-11
  • 老生常談js動(dòng)態(tài)添加事件--- 事件委托

    老生常談js動(dòng)態(tài)添加事件--- 事件委托

    下面小編就為大家?guī)硪黄仙U刯s動(dòng)態(tài)添加事件--- 事件委托。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-07-07
  • 微信小程序收藏功能的實(shí)現(xiàn)代碼

    微信小程序收藏功能的實(shí)現(xiàn)代碼

    這篇文章主要介紹了微信小程序收藏功能的實(shí)現(xiàn)代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06
  • 第一次接觸神奇的Bootstrap基礎(chǔ)排版

    第一次接觸神奇的Bootstrap基礎(chǔ)排版

    第一次接觸神奇的Bootstrap基礎(chǔ)排版,Bootstrap讓W(xué)eb開發(fā)更迅速、更簡(jiǎn)單,感興趣的小伙伴們可以參考一下
    2016-07-07
  • js生成隨機(jī)數(shù)的方法實(shí)例

    js生成隨機(jī)數(shù)的方法實(shí)例

    這篇文章主要內(nèi)容是對(duì)js生成隨機(jī)數(shù)方法的實(shí)例匯總,js生成隨機(jī)數(shù)主要用到了內(nèi)置的Math對(duì)象的random()方法,需要的朋友可以參考下
    2015-10-10
  • 整理Javascript流程控制語句學(xué)習(xí)筆記

    整理Javascript流程控制語句學(xué)習(xí)筆記

    整理Javascript流程控制語句學(xué)習(xí)筆記,之前一系列的文章是跟我學(xué)習(xí)Javascript,本文就是進(jìn)一步學(xué)習(xí)javascript流程控制語句,希望大家繼續(xù)關(guān)注
    2015-11-11
  • JavaScript原生數(shù)組函數(shù)實(shí)例匯總

    JavaScript原生數(shù)組函數(shù)實(shí)例匯總

    這篇文章主要介紹了JavaScript原生數(shù)組函數(shù)實(shí)例匯總,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10

最新評(píng)論