js动态计算table某列值的总和

  1. /**  
  2.  *   
  3.  * @tableId 表格id  
  4.  * @numId 显示张数id  
  5.  * @index 列数  
  6.  * @first 首次标识  
  7.  * @obj checkbox对象  
  8.  */  
  9. function countNum(tableId, numId, index, first,obj) {   
  10.     var sumStr = document.getElementById(numId);   
  11.     //当前行进行加减   
  12.     if (null != obj) {   
  13.         var num = new Number(obj.parentElement.parentElement.cells[index].innerText);   
  14.         if (obj.checked) {   
  15.             sumStr.value = new Number(sumStr.value) + num;   
  16.         }   
  17.         else {   
  18.             sumStr.value = new Number(sumStr.value) - num;   
  19.         }   
  20.     }   
  21.     //遍历所有进行加减   
  22.     else {   
  23.         var table = document.getElementById(tableId);   
  24.         var sum = 0;   
  25.         var rows = table.rows;   
  26.         for (i = 1; i < rows.length; i++) {   
  27.                                                 //判断是否有复选框   
  28.             var checkObj = rows[i].cells[0].all[0];   
  29.             var flag = false;   
  30.             if (null != checkObj    
  31.                 && typeof checkObj.type != 'undefined'  
  32.                 &&  checkObj.type == 'checkbox') {   
  33.                 flag = checkObj.checked;   
  34.             }   
  35.                                                 //首次默认计算全部或增加选中的值   
  36.             if (first || flag) {   
  37.                 var num = new Number(rows[i].cells[index].innerText);   
  38.                 sum = sum + num;   
  39.             }   
  40.         }   
  41.         sumStr.value = sum;   
  42.     }   
  43. }  

你可能感兴趣的:(js动态计算table某列值的总和)