JS實現的表格操作類詳解(添加,刪除,排序,上移,下移),

來源:互聯網
上載者:User

JS實現的表格操作類詳解(添加,刪除,排序,上移,下移),

本文執行個體講述了JS實現的表格操作類。分享給大家供大家參考,具體如下:

運行效果如下:

點擊此處查看線上示範。

具體代碼如下:

<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <style type="text/css">*{font-size:14px}button{margin:3px}</style> <script type="text/javascript"> var mytable=null,mytable2=null; window.onload=function(){ mytable=new CTable("tbl",10); mytable2=new CTable("tbl2",6); } Array.prototype.each=function(f){for(var i=0;i<this.length;i++) f(this[i],i,this)} function $A(arrayLike){ for(var i=0,ret=[];i<arrayLike.length;i++) ret.push(arrayLike[i]); return ret } Function.prototype.bind = function() {  var __method = this, args = $A(arguments), object = args.shift();  return function() {   return __method.apply(object, args.concat($A(arguments)));  } } function CTable(id,rows){ this.tbl=typeof(id)=="string"?document.getElementById(id):id; if (rows && /^\d+$/.test(rows)) this.addrows(rows) } CTable.prototype={ addrows:function(n){ //隨機添加n個tr new Array(n).each(this.add.bind(this)) }, add:function(){ //添加1個tr var self=this; var tr = self.tbl.insertRow(-1),td1= tr.insertCell(-1),td2= tr.insertCell(-1),td3= tr.insertCell(-1); var chkbox=document.createElement("INPUT") chkbox.type="checkbox" chkbox.onclick=self.highlight.bind(self) td1.appendChild(chkbox) td1.setAttribute("width","35") td2.innerHTML=Math.ceil(Math.random()*99) td3.innerHTML=Math.ceil(Math.random()*99) }, del:function(){ //刪除所選tr var self=this $A(self.tbl.rows).each(function(tr){if (self.getChkBox(tr).checked) tr.parentNode.removeChild(tr)}) }, up:function(){ //上移所選tr var self=this var upOne=function(tr){ //上移1個tr if (tr.rowIndex>0){ self.swapTr(tr,self.tbl.rows[tr.rowIndex-1]) self.getChkBox(tr).checked=true } } var arr=$A(self.tbl.rows).reverse() if (arr.length>0 && self.getChkBox(arr[arr.length-1]).checked){ for(var i=arr.length-1;i>=0;i--){ if (self.getChkBox(arr[i]).checked){ arr.pop()      }else{ break } } } arr.reverse().each(function(tr){if (self.getChkBox(tr).checked) upOne(tr)}); }, down:function(){ var self=this var downOne=function(tr){    if (tr.rowIndex<self.tbl.rows.length-1) { self.swapTr(tr,self.tbl.rows[tr.rowIndex+1]); self.getChkBox(tr).checked=true; } } var arr=$A(self.tbl.rows) if (arr.length>0 && self.getChkBox(arr[arr.length-1]).checked){ for(var i=arr.length-1;i>=0;i--){ if (self.getChkBox(arr[i]).checked){ arr.pop() }else{ break } } } arr.reverse().each(function(tr){if (self.getChkBox(tr).checked) downOne(tr)}); }, sort:function(){ //排序  var self=this,order=arguments[0]; var sortBy=function(a,b){ if (typeof(order)=="number"){ //數字,則按數字指示的列排序 return Number(a.cells[order].innerHTML)>=Number(b.cells[order].innerHTML)?1:-1;  //轉化為數字類型比較大小 }else if (typeof(order)=="function"){ //為程式,按 程式的返回結果排序 return order(a,b); }else{ return 1; } } $A(self.tbl.rows).sort(sortBy).each(function(x){ var checkStatus=self.getChkBox(x).checked; self.tbl.firstChild.appendChild(x); if (checkStatus) self.getChkBox(x).checked=checkStatus; }); }, rnd:function(){ //隨即選擇幾行tr var self=this,selmax=0,tbl=self.tbl; if (tbl.rows.length){  selmax=Math.max(Math.ceil(tbl.rows.length/4),1); //選擇的行數不超過tr數的1/4  $A(tbl.rows).each(function(x){ self.getChkBox(x).checked=false; self.restoreBgColor(x) }) }else{ return alert("無資料可以選") } new Array(selmax).each(function(){ var tr=tbl.rows[Math.floor(Math.random()*tbl.rows.length)] self.getChkBox(tr).checked=true; self.highlight({target:self.getChkBox(tr)}) }) }, highlight:function(){        //設定tr的背景色 var self=this; var evt=arguments[0] || window.event var chkbox=evt.srcElement || evt.target var tr=chkbox.parentNode.parentNode chkbox.checked?self.setBgColor(tr):self.restoreBgColor(tr) }, swapTr:function(tr1,tr2){       //交換tr1和tr2的位置 var target=(tr1.rowIndex<tr2.rowIndex)?tr2.nextSibling:tr2; var tBody=tr1.parentNode tBody.replaceChild(tr2,tr1);   tBody.insertBefore(tr1,target); }, getChkBox:function(tr){      //從tr得到 checkbox對象 return tr.cells[0].firstChild }, restoreBgColor:function(tr){      tr.style.backgroundColor="#ffffff" }, setBgColor:function(tr){ tr.style.backgroundColor="#c0c0c0" } } function f(a,b){ var sumRow=function(row){return Number(row.cells[1].innerHTML)+Number(row.cells[2].innerHTML)}; return sumRow(a)>sumRow(b)?1:-1; } </script> </head> <body> <button onClick="javascript:mytable.rnd()">隨機播放行</button> <button onClick="javascript:mytable.add()">添加一行</button> <button onClick="javascript:mytable.del()">刪除選定行</button> <button onClick="javascript:mytable.up()">上移選定行</button> <button onClick="javascript:mytable.down()">下移選定行</button> <button onClick="javascript:mytable.sort(1)">按第一列數字排序</button> <button onClick="javascript:mytable.sort(f)">按每行資料的和排序</button> <table width=100%> <tr> <td valign="top"><table border id="tbl" width="80%"></table></td> <td valign="top"><table border id="tbl2" width="80%"></table></td> </tr> </table> <button onClick="javascript:mytable2.rnd()">隨機播放行</button> <button onClick="javascript:mytable2.add()">添加一行</button> <button onClick="javascript:mytable2.del()">刪除選定行</button> <button onClick="javascript:mytable2.up()">上移選定行</button> <button onClick="javascript:mytable2.down()">下移選定行</button> <button onClick="javascript:mytable2.sort(2)">按第二列數字排序</button> <button onClick="javascript:mytable2.sort(f)">按每行資料的和排序</button> </body> </html>

希望本文所述對大家JavaScript程式設計有所協助。

您可能感興趣的文章:
  • 基於JavaScript實現動態建立表格和增加表格行數
  • JS組件Bootstrap Table表格行拖拽效果實現代碼
  • JS實現的表格行滑鼠點擊高亮效果代碼
  • javascript實現對錶格元素進行排序操作
  • JavaScript如何動態建立table表格
  • js操作table元素實現表格行列新增、刪除技巧總結
  • js擷取表格的行數和列數的方法
  • JS+CSS實現表格高亮的方法
  • JavaScript擷取表格(table)當前行的值、刪除行、增加行
  • 原生JS和JQuery動態添加、刪除表格行的方法
  • JavaScript對錶格或元素按文本,數字或日期排序的方法

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.