如何动态计算HTML页面上表格中每列的总和?

问题描述 投票:2回答:2

我基本上会有一个表格,其中包含一周中的几天(标题行)。第1栏 - 星期日,第2栏 - 星期一等。每个单元格将以工作小时数输入,即8。在将数据输入每个单元格之后,我希望每个单元格在其列中动态计算其上方单元格总数的最后一行。理想情况下,应在将光标移动到其他单元格后计算。

好像我应该使用一些JavaScript。但我无法从头开始编写JavaScript;我只能在写完之后把它调整到我需要的东西。

为了我们的目的,这是一个基本的表格。我将在第1列中列举示例。

<table id="workweek" class="wwtable">
<tr><th>sunday</th><th>monday</th><th>tuesday</th><th>wednesday</th><th>thursday</th><th>friday</th><th>saturday</th></tr>
<tr><td>8 </td><td> </td><td> </td><td> </td><td> </td><td> </td><td> </td></tr>
<tr><td>8 </td><td> </td><td> </td><td> </td><td> </td><td> </td><td> </td></tr>
<tr><td>8 </td><td> </td><td> </td><td> </td><td> </td><td> </td><td> </td></tr>
<tr><td>8 </td><td> </td><td> </td><td> </td><td> </td><td> </td><td> </td></tr>
<tr><td>8 </td><td> </td><td> </td><td> </td><td> </td><td> </td><td> </td></tr>
<tr><td>(Calculate 40 here) </td><td> </td><td> </td><td> </td><td> </td><td> </td><td> </td></tr>
</table>

忘了提。每个单元格将让用户输入每天的小时数,因此每个单元格中都有输入字段。

javascript html html-table cell calculated-columns
2个回答
4
投票

如果jQuery是一个可行的选项,你可以遍历给定列中的所有td,如下所示:

$('#workweek>tbody>tr>td:nth-child(1)').each( function(){
    sum += parseInt($(this).text()) || 0;
});

我为你on jsFiddle做了一个工作的例子:

for (var i=1; i<8; i++)
{
    var sum = 0;

    // iteration through all td's in the column
    $('#workweek>tbody>tr>td:nth-child(' + i + ')').each( function(){
        sum += parseInt($(this).text()) || 0;
    });

    // set total in last cell of the column
    $('#workweek>tbody>tr>td:nth-child(' + i + ')').last().html(sum);
}

请注意,如果该列不为空,则此示例将擦除列的最后一个单元格的内容。


2
投票

您可以循环遍历表格的DOM,并将每个单元格的textContentinnerText作为小时值。

这是一种流行的方式:

function strip(html) {
    var tmp = document.createElement("DIV");
    tmp.innerHTML = html;
    return tmp.textContent||tmp.innerText;
}

然后(像这样):工作示例:http://jsfiddle.net/7srJf/3/

var tbl = document.getElementById('my-table');
var rows = tbl.rows;
var DAYS_OF_WEEK = 2, totals = [0, 0];
for (var i = 0; i < DAYS_OF_WEEK; i++) { 
    for (var j = 1; j < rows.length; j++) {
      var cell = rows[j].cells[i];
      var numHours = parseInt(strip(cell.innerHTML), 10);
      totals[i] += numHours;
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.