HTML表 - 迭代行并对字段求和

时间:2015-07-03 09:49:57

标签: javascript jquery iteration html-table

我接下来是表:

    <table style="width:100%" id="testTable">
    <tr>
        <th>length per</th>
        <th>width per</th> 
        <th>length</th>
        <th>width</th>
        <th>total</th>
    </tr>
    <tr align='right'>
        <td>
            <input type="text" name="length-per-input">
        </td>
        <td>
            <input type="text" name="width-per-input">
        </td> 
        <td>
            <input type="text" name="length-total-input">
        </td>
        <td>
            <input type="text" name="width-total-input">
        </td>
        <td>
            <input type="text" name="total-output" disabled="disabled">
        </td>
    </tr>
    <tr align='right'>
        <td>
            <input type="text" name="length-per-input">
        </td>
        <td>
            <input type="text" name="width-per-input">
        </td> 
        <td>
            <input type="text" name="length-total-input">
        </td>
        <td>
            <input type="text" name="width-total-input">
        </td>
        <td>
            <input type="text" name="total-output" disabled="disabled">
        </td>
    </tr>
</table>

<input type=button value='+' onclick="addRow()" />
<input type=button value='Calculate' onclick="Calculate()" />

我还有javascript,它添加了值并将其总计:

<script>
    function Calculate() {
        var lengthPerInput = $("input[name='length-per-input']").val();
        var widthPerInput = $("input[name='width-per-input']").val();
        var lengthTotal = $("input[name='length-total-input']").val();
        var widthTotal = $("input[name='width-total-input']").val();
        var total = (lengthTotal/lengthPerInput) + (widthTotal/widthPerInput);
        $("input[name='total-output']").val(total);
    }
</script>

这里的目的是让它迭代两行,然后分别添加每一行。 我知道如何使用以下方式获取每一行:

$('#testTable tr').each(function(){
    console.log(this);
    $(this).find('length-per-input').each(function(){
        console.log(this);
    })
})

但是使用该行(通过&#34访问;此&#34;)我不知道如何获取正确的单元格,获取它们的值,然后在该行上执行计算总计。

对此有任何建议吗?谢谢!

2 个答案:

答案 0 :(得分:1)

    function Calculate(tr_row) {
        var lengthPerInput = tr_row.find("input[name='length-per-input']").val();
        var widthPerInput = tr_row.find("input[name='width-per-input']").val();
        var lengthTotal = tr_row.find("input[name='length-total-input']").val();
        var widthTotal = tr_row.find("input[name='width-total-input']").val();
        var total = (lengthTotal/lengthPerInput) + (widthTotal/widthPerInput);
        tr_row.find("input[name='total-output']").val(total);
    }

对于每一行调用函数来汇总值 对于传递行的函数,它可以收集该行的值

$('#testTable tr').each(function(){
    Calculate($(this))   
})

答案 1 :(得分:0)

您可以使用each()函数迭代table并使用find()函数查找cell值。

function Calculate() {
  $('#testTable tr').each(function() {
    var lengthPerInput = $(this).find("input[name='length-per-input']").val();
    var widthPerInput = $(this).find("input[name='width-per-input']").val();
    var lengthTotal = $(this).find("input[name='length-total-input']").val();
    var widthTotal = $(this).find("input[name='width-total-input']").val();
    var total = (lengthTotal/lengthPerInput) + (widthTotal/widthPerInput);
    $(this).find("input[name='total-output']").val(total);
  });
}

Working Plunker

How to get a table cell value using jQuery?