For example, given two dates in input boxes:
<input id="first" value="1/1/2000"/> <input id="second" value="1/1/2001"/> <script> alert(datediff("day", first, second)); // what goes here? </script>
How do I get the number of days between two dates in JavaScript?
Here is a quick and dirty implementation of
datediff, as a proof of concept to solve the problem as presented in the question. It relies on the fact that you can get the elapsed milliseconds between two dates by subtracting them, which coerces them into their primitive number value (milliseconds since the start of 1970).You should be aware that the "normal" Date APIs (without "UTC" in the name) operate in the local timezone of the user’s browser, so in general you could run into issues if your user is in a timezone that you don’t expect, and your code will have to deal with Daylight Saving Time transitions. You should carefully read the documentation for the Date object and its methods, and for anything more complicated, strongly consider using a library that offers more safe and powerful APIs for date manipulation.
Date— MDN JavaScript referenceAlso, for illustration purposes, the snippet uses named access on the
windowobject for brevity, but in production you should use standardized APIs like getElementById, or more likely, some UI framework.