Reputation: 837
I am developing a web-based application to capture start time and end time from system date-time but my main problem is that I don't know how can I get the duration time, between start and end time for downtime.
//Function to get current start time
var startTime = setInterval(function () { start() }, 1000);
function start() {
var startDate = new Date();
var timeStart = startDate.toLocaleTimeString();
$("#setCount").html(timeStart);
}
Upvotes: 32
Views: 108880
Reputation: 742
function formatDate(difference) {
//Arrange the difference of date in days, hours, minutes, and seconds format
let days = Math.floor(difference / (1000 * 60 * 60 * 24));
let hours = Math.floor((difference % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
let minutes = Math.floor((difference % (1000 * 60 * 60)) / (1000 * 60));
let seconds = Math.floor((difference % (1000 * 60)) / 1000);
return "Total time elapsed is: " + days + " days " + hours + " hours " + minutes + " minutes " + seconds + " seconds.";
}
let start = new Date("December 31, 2020 23:59:59");
let end = new Date();
let difference = end - start;
console.log(formatDate(difference));
Upvotes: 0
Reputation: 3118
I have this function to show the time distance between two dates:
const timeDistance = (date1, date2) => {
let distance = Math.abs(date1 - date2);
const hours = Math.floor(distance / 3600000);
distance -= hours * 3600000;
const minutes = Math.floor(distance / 60000);
distance -= minutes * 60000;
const seconds = Math.floor(distance / 1000);
return `${hours}:${('0' + minutes).slice(-2)}:${('0' + seconds).slice(-2)}`;
};
console.log(timeDistance(new Date(0), new Date()))
The output in the format h:mm:ss
hours can grow arbitrary.
Upvotes: 7
Reputation:
Update:
If you want to display the time difference to user, Serigo's
method
will do it. But if it is for any development purposes, below functions will make your life easy.
Just wanted to let you know about this console utility functions.
Put this line in top of your app initialization code console.time('appLifeTime');
Put this one in where ever you feel that your app ends. console.timeEnd('appLifeTime');
console.time('appLifeTime');
setTimeout(function delay(){
console.timeEnd('appLifeTime');
}, 1500);
The above code piece will print, appLifeTime: 1500.583ms
.
AFAIK, console.time & console.timeEnd
works in firefox(with firebug) & webkit browsers(chrome, safari).
Upvotes: 19
Reputation: 35950
To simply measure time elapsed, use Date.getTime()
which outputs current time in milliseconds since unix epoch.
You can substract one millis value from another to get the duration.
Example:
var startTime = new Date().getTime();
setTimeout(function () {
var endTime = new Date().getTime();
console.log("duration [ms] = " + (endTime-startTime));
}, 1500);
Output would be, of course: duration [ms] = 1500
(or couple ms less or more).
Upvotes: 9
Reputation: 6948
Do you mean this:
var date1 = new Date();
var date2 = new Date();
var diff = date2 - date1;
console.log("milliseconds interval:" + diff)
upd
check JSFiddle
Upvotes: 54
Reputation: 742
let output = document.getElementById('output');
function formatDate(difference) {
//Arrange the difference of date in days, hours, minutes, and seconds format
let days = Math.floor(difference / (1000 * 60 * 60 * 24));
let hours = Math.floor((difference % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
let minutes = Math.floor((difference % (1000 * 60 * 60)) / (1000 * 60));
let seconds = Math.floor((difference % (1000 * 60)) / 1000);
output.innerHTML += "Total time elapsed is: " + days + " days " + hours + " hours " + minutes + " minutes " + seconds + " seconds.";
}
let start = new Date("December 31, 2020 23:59:59");
let end = new Date();
let difference = end - start;
formatDate(difference);
<h3> Using the <i> Date() object </i> to find the time elapsed in JavaScript </h3>
<div id="output"></div>
Upvotes: 0
Reputation: 57309
Use this nifty jQuery plugin: http://timeago.yarp.com/
Timeago is a jQuery plugin that makes it easy to support automatically updating fuzzy timestamps (e.g. "4 minutes ago" or "about 1 day ago"). Download, view the examples, and enjoy.
You opened this page about a minute ago. (This will update every minute. Wait for it.)
This page was last modified 13 days ago.
Ryan was born 34 years ago.
Upvotes: 1