将秒数转换为天,小时,分钟和秒

问题描述 投票:15回答:5

我有一个带有停止按钮的无限循环的Javascript计时事件。

点击开始按钮时会显示数字。现在我想将这些数字转换为4小时3分50秒

var c = 0;
var t;
var timer_is_on = 0;

function timedCount() {
  document.getElementById('txt').value = c;
  c = c + 1;
  t = setTimeout(function() {
    timedCount()
  }, 1000);
}

function doTimer() {
  if (!timer_is_on) {
    timer_is_on = 1;
    timedCount();
  }
}

function stopCount() {
  clearTimeout(t);
  timer_is_on = 0;

}

$(".start").on("click", function() {
  //var start = $.now();
  //alert(start);
  //console.log(start);
  doTimer();
  $(".end").show();
  $(".hide_div").show();
});
$(".end").on("click", function() {
  stopCount();
});
.hide_div {
  display: none;
}

.end {
  display: none;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<p class="start">Start</p>
<p class="end">End</p>
<p class="hide_div">
  <input type="text" id="txt" />//display numbers eg 12345
</p>

如何将123456之类的数字转换为1天,4小时,40分钟,45秒?

javascript
5个回答
21
投票

像这样使用MathparseInt中的第二个参数是基数,这是可选的

var seconds = parseInt(123456, 10);

var days = Math.floor(seconds / (3600*24));
seconds  -= days*3600*24;
var hrs   = Math.floor(seconds / 3600);
seconds  -= hrs*3600;
var mnts = Math.floor(seconds / 60);
seconds  -= mnts*60;
console.log(days+" days, "+hrs+" Hrs, "+mnts+" Minutes, "+seconds+" Seconds");

你给定的秒123456将是1 days, 10 Hrs, 17 Minutes, 36 Seconds而不是1 days, 4 Hrs, 40 Minutes, 45 Seconds


16
投票

我建议这样做!:

function secondsToDhms(seconds) {
seconds = Number(seconds);
var d = Math.floor(seconds / (3600*24));
var h = Math.floor(seconds % (3600*24) / 3600);
var m = Math.floor(seconds % 3600 / 60);
var s = Math.floor(seconds % 60);

var dDisplay = d > 0 ? d + (d == 1 ? " day, " : " days, ") : "";
var hDisplay = h > 0 ? h + (h == 1 ? " hour, " : " hours, ") : "";
var mDisplay = m > 0 ? m + (m == 1 ? " minute, " : " minutes, ") : "";
var sDisplay = s > 0 ? s + (s == 1 ? " second" : " seconds") : "";
return dDisplay + hDisplay + mDisplay + sDisplay;
}

3
投票
// countdown(3546544) -> 41d 1h 9m 4s
// countdown(436654) -> 5d 1h 17m 34s
// countdown(3601) -> 1h 0m 1s
// countdown(121) -> 2m 1s
const countdown = (function () {
    const pad = t => {
        return (t + '').length < 2 ? pad('0' + t + '') : t ;
    }
    return s => {

        const d = Math.floor(s / (3600 * 24));

        s  -= d * 3600 * 24;

        const h   = Math.floor(s / 3600);

        s  -= h * 3600;

        const m = Math.floor(s / 60);

        s  -= m * 60;

        const tmp = [];

        (d) && tmp.push(d + 'd');

        (d || h) && tmp.push(h + 'h');

        (d || h || m) && tmp.push(m + 'm');

        tmp.push(s + 's');

        return tmp.join(' ');
    }
}());

2
投票

我用map()和reduce()的解决方案:

const intervalToLevels = (interval, levels) => {
  const cbFun = (d, c) => {
    let bb = d[1] % c[0],
      aa = (d[1] - bb) / c[0];
    aa = aa > 0 ? aa + c[1] : '';

    return [d[0] + aa, bb];
  };

  let rslt = levels.scale.map((d, i, a) => a.slice(i).reduce((d, c) => d * c))
    .map((d, i) => ([d, levels.units[i]]))
    .reduce(cbFun, ['', interval]);
  return rslt[0];
};

const TimeLevels = {
  scale: [24, 60, 60, 1],
  units: ['d ', 'h ', 'm ', 's ']
};
const secondsToString = interval => intervalToLevels(interval, TimeLevels);

如果你打电话给secondsToString(123456),你可以得到“1d 10h 17m 36s”


0
投票

您可能会发现使用纪元时间戳更直接:如此处详细介绍Convert a Unix timestamp to time in JavaScript,基本方法如下:

                    <script>

                     // Create a new JavaScript Date object based on the timestamp
                            // multiplied by 1000 so that the argument is in milliseconds, not seconds.
                            var date1 = new Date();

                            alert ('easy trick to waste a few seconds...' + date1);


                            // var date = date2 - date1;

                            // Hours part from the timestamp
                            var hours1 = date1.getHours();
                            // Minutes part from the timestamp
                            var minutes1 = "0" + date1.getMinutes();
                            // Seconds part from the timestamp
                            var seconds1 = "0" + date1.getSeconds();



                            var date2 = new Date();

                            // Hours part from the timestamp
                            var hours2 = date2.getHours();
                            // Minutes part from the timestamp
                            var minutes2 = "0" + date2.getMinutes();
                            // Seconds part from the timestamp
                            var seconds2 = "0" + date2.getSeconds();



                            // Will display time in 10:30:23 format
                            // var formattedTime = hours + ':' + minutes.substr(-2) + ':' + seconds.substr(-2);


                            var  elapsedHrs = hours2 - hours1;
                            var  elapsedMin = minutes2.substr(-2) -minutes1.substr(-2);
                            var elapsedSec = seconds2.substr(-2) - seconds1.substr(-2);                                

                            var elapsedTime = elapsedHrs + ' hours, ' + elapsedMin + ' minutes, ' + elapsedSec + ' seconds';

                            alert ('time between timestamps: ' + elapsedTime);

                    </script>

请注意,这个脚本需要一些工作,因为现在它会为date1 = 12:00:00和date2 = 12:00:05之类的东西提供负值,但我现在就把它留给你。您应该重写代码以在计时器开始时采用时间戳(var x = new Date();),并在完成/想要检查已用时间时使用时间戳,并在解析经过的秒,分钟之前减去两个小时等等。

© www.soinside.com 2019 - 2024. All rights reserved.