gpt4 book ai didi

javascript - 计算耗时并将其放入天数 :Hours:Minutes:Seconds format in javascript where time elapsed updates every second

转载 作者:行者123 更新时间:2023-11-29 10:27:03 26 4
gpt4 key购买 nike

我正在尝试计算设定的日期时间对象和当前时间之间耗时。我希望它能够以这种格式出现 DD:HH:MM:SS 其中 DD 是天,HH 是小时,MM 是分钟,SS 是秒。我能够得到总天数、总小时数、总分钟数和总秒数,但我不确定如何按照我想要的方式对其进行格式化。请帮忙

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>timer</title>
</head>
<body >
<div id ="time" name ="timer"></div>

<script>
var myVar = setInterval(myTimer, 1000);

function myTimer() {

let seconds = 1000 ;
let minutes = seconds * 60;
let hours = minutes * 60;
let days = hours * 24;
let years = days * 365;


const startDateTime = new Date("June 2, 2019 12:36:10 AM");
const newDateTime = new Date();

let timeDiff = newDateTime - startDateTime;

let totalSeconds = Math.round(timeDiff/seconds);


document.getElementById("time").innerHTML = totalSeconds;
}
</script>

</body>

</html>

最佳答案

我建议您使用类似 Moment.js 的库,但是如果您想在纯 Javascript 中执行此操作,您可以将总秒数除以您已经定义的除法参数,并在它们小于 10 时用零填充它们。

var myVar = setInterval(myTimer, 1000);

const seconds = 1000;
const minutes = seconds * 60;
const hours = minutes * 60;
const days = hours * 24;
const years = days * 365;

function myTimer() {
const startDateTime = new Date("June 2, 2019 12:36:10 AM");
const newDateTime = new Date();

let elapsedMilliseconds = newDateTime - startDateTime;

document.getElementById("time").innerHTML =
`${formatElapsedTime(elapsedMilliseconds, days)}:${formatElapsedTime(elapsedMilliseconds, hours, 24)}:${formatElapsedTime(elapsedMilliseconds, minutes, 60)}:${formatElapsedTime(elapsedMilliseconds, seconds, 60)}`;
}

function formatElapsedTime(elapsedtime, timeunit, base) {
let time = base ? (elapsedtime / timeunit) % base : elapsedtime / timeunit;
time = Math.floor(time);
time = time < 10 ? '0' + time : time;
return time;
}
<!DOCTYPE html>
<html lang="en">

<head>
<meta charset="UTF-8">
<title>timer</title>
</head>

<body>
<div id="time" name="timer"></div>
</body>

</html>

关于javascript - 计算耗时并将其放入天数 :Hours:Minutes:Seconds format in javascript where time elapsed updates every second,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56419249/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com