最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Calculate the sum of the time for column - Stack Overflow

programmeradmin3浏览0评论

I have this table:

<table id="total" border="1" width="100%">
    <tbody>
        <tr>
            <td>Total duration time</td>
            <td class="total_duration_time"></td>
        </tr>
    </tbody>
</table>
<table id="data" border="1" width="100%">
    <tbody>
        <tr>
            <td>Anna</td>
            <td>318</td><td class="duration_time">00:00:50</td>
            <td>62700</td>
        </tr>
        <tr>
            <td>Bob</td>
            <td>318</td>
            <td class="duration_time">00:00:27</td>
            <td>62703</td>
        </tr>
        <tr>
            <td>Mike</td>
            <td>318</td>
            <td class="duration_time">00:00:36</td>
            <td>88455233284</td>
        </tr>
    </tbody>
</table>

I need to calculate the sum of the column with class duration_time and print result in to column with class total_duration_time.

How to do this on JavaScript or jQuery?

I tried to use the code from this example /, but it does not calculate the amount of time if instead of numbers substitute a value of type 00:00:00.

I have this table:

<table id="total" border="1" width="100%">
    <tbody>
        <tr>
            <td>Total duration time</td>
            <td class="total_duration_time"></td>
        </tr>
    </tbody>
</table>
<table id="data" border="1" width="100%">
    <tbody>
        <tr>
            <td>Anna</td>
            <td>318</td><td class="duration_time">00:00:50</td>
            <td>62700</td>
        </tr>
        <tr>
            <td>Bob</td>
            <td>318</td>
            <td class="duration_time">00:00:27</td>
            <td>62703</td>
        </tr>
        <tr>
            <td>Mike</td>
            <td>318</td>
            <td class="duration_time">00:00:36</td>
            <td>88455233284</td>
        </tr>
    </tbody>
</table>

I need to calculate the sum of the column with class duration_time and print result in to column with class total_duration_time.

How to do this on JavaScript or jQuery?

I tried to use the code from this example http://jsfiddle/unKDk/13/, but it does not calculate the amount of time if instead of numbers substitute a value of type 00:00:00.

Share Improve this question edited Jun 13, 2013 at 15:20 Adil Shaikh 44.8k17 gold badges95 silver badges112 bronze badges asked Jun 13, 2013 at 15:19 n1k1c4n1k1c4 531 gold badge2 silver badges6 bronze badges 2
  • 2 You're going to have to manually parse the times. You could use a regex, or split by :, and do the math yourself – Ian Commented Jun 13, 2013 at 15:20
  • Here's what I got: jsfiddle/5gXSm . It doesn't figure out carrying over - for example, if the number of seconds goes over 60, it shouldn't bee 61 - it should increase the number of minutes and reset to 0. I'll leave that up to you – Ian Commented Jun 13, 2013 at 15:44
Add a ment  | 

4 Answers 4

Reset to default 5

The easiest way is to work with seconds. I mean, you can convert each duration to seconds, make the total and then show where you need using another function that converts the seconds to hh-mm-ss format.

You can check how it looks and it works here

Note : the function toHHMMSS() is taken form here

Here's a full example with carry (assuming the format is HOURS:MINUTES:SECONDS), maybe not the best solution for putation:

HTML

<table id="sum_table" width="300" border="1">
<tr class="titlerow">
    <td>Apple</td>
    <td>Orange</td>
    <td>Watermelon</td>
</tr>
<tr>
    <td class="rowDataSd">00:55:23</td>
    <td class="rowDataSd">00:55:23</td>
    <td class="rowDataSd">00:55:23</td>
</tr>
<tr>
    <td class="rowDataSd">00:55:23</td>
    <td class="rowDataSd">00:55:23</td>
    <td class="rowDataSd">00:55:23</td>
</tr>
<tr>
    <td class="rowDataSd">00:55:23</td>
    <td class="rowDataSd">00:55:23</td>
    <td class="rowDataSd">00:55:22</td>
</tr>
<tr class="totalColumn">
    <td class="totalCol">Total:</td>
    <td class="totalCol">Total:</td>
    <td class="totalCol">Total:</td>
</tr>
</table>

JS

var totals = [[0,0,0], [0,0,0], [0,0,0]];
$(document).ready(function () {

var $dataRows = $("#sum_table tr:not('.totalColumn, .titlerow')");

$dataRows.each(function () {
    $(this).find('.rowDataSd').each(function (i) {
        time = $(this).html().split(":")
        totals[i][2] += parseInt(time[2]);
        if(totals[i][2] > 60)
        {
            totals[i][2] %= 60;
            totals[i][1] += parseInt(time[1]) + 1;          
        }
        else
            totals[i][1] += parseInt(time[1]);

        if(totals[i][1] > 60)
        {
            totals[i][1] %= 60;
            totals[i][0] += parseInt(time[0]) + 1;          
        }
        else
            totals[i][0] += parseInt(time[0]);
    });
});
$("#sum_table td.totalCol").each(function (i) {
    console.log(totals[i]);
    $(this).html("total:" + totals[i][0] + ":" + totals[i][1] + ":" + totals[i][2]);
});

});

http://jsfiddle/unKDk/192/

You can calculate total time by using 24hr format time inputs

var a = "22:00"
var b = "01:00"

Fiddle Demo :

Time Calculation Example, https://github./Zalasanjay

You will need to do something like this, I haven't tested it extensively, so there may be problems, but you should get the idea.

Javascript

var totalDurationTime = document.getElementsByClassName("total_duration_time")[0],
    durationTimes = document.getElementsByClassName("duration_time"),
    total = {
        hours: 0,
        minutes: 0,
        seconds: 0
    };

function zeroPad (num) {
    var str = num.toString();

    if (str.length < 2) {
        str = "0" + str;
    }

    return str;
}

Array.prototype.forEach.call(durationTimes, function (time) {
    var parts = time.textContent.split(":"),
        temp;

    temp = (+parts[2] + total.seconds);
    total.seconds = temp % 60;    
    temp = (+parts[1] + total.minutes) + (temp - total.seconds) / 60;
    total.minutes = temp % 60;    
    total.hours = (+parts[0] + total.hours) + (temp - total.minutes) / 60;
});

totalDurationTime.textContent = zeroPad(total.hours) + ":" + zeroPad(total.minutes) + ":" + zeroPad(total.seconds);

On jsfiddle

发布评论

评论列表(0)

  1. 暂无评论