W3cubDocs

/JavaScript

Date

JavaScript Date objects represent a single moment in time in a platform-independent format. Date objects contain a Number that represents milliseconds since 1 January 1970 UTC.

TC39 is working on Temporal, a new Date/Time API.
Read more about it on the Igalia blog and fill out the survey. It needs real-world feedback from web developers, but is not yet ready for production use!

Description

The ECMAScript epoch and timestamps

A JavaScript date is fundamentally specified as the number of milliseconds that have elapsed since midnight on January 1, 1970, UTC. This date and time are not the same as the UNIX epoch (the number of seconds that have elapsed since midnight on January 1, 1970, UTC), which is the predominant base value for computer-recorded date and time values.

Note: It's important to keep in mind that while the time value at the heart of a Date object is UTC, the basic methods to fetch the date and time or its components all work in the local (i.e. host system) time zone and offset.

It should be noted that the maximum Date is not of the same value as the maximum safe integer (Number.MAX_SAFE_INTEGER is 9,007,199,254,740,991). Instead, it is defined in ECMA-262 that a maximum of ±100,000,000 (one hundred million) days relative to January 1, 1970 UTC (that is, April 20, 271821 BCE ~ September 13, 275760 CE) can be represented by the standard Date object (equivalent to ±8,640,000,000,000,000 milliseconds).

Date format and time zone conversions

There are several methods available to obtain a date in various formats, as well as to perform time zone conversions. Particularly useful are the functions that output the date and time in Coordinated Universal Time (UTC), the global standard time defined by the World Time Standard. (This time is historically known as Greenwich Mean Time, as UTC lies along the meridian that includes London—and nearby Greenwich—in the United Kingdom.) The user's device provides the local time.

In addition to methods to read and alter individual components of the local date and time (such as getDay() and setHours()), there are also versions of the same methods that read and manipulate the date and time using UTC (such as getUTCDay() and setUTCHours()).

Constructor

Date()
Creates a new Date object.

Static methods

Date.now()
Returns the numeric value corresponding to the current time—the number of milliseconds elapsed since January 1, 1970 00:00:00 UTC, with leap seconds ignored.
Date.parse()
Parses a string representation of a date and returns the number of milliseconds since 1 January, 1970, 00:00:00 UTC, with leap seconds ignored.

Note: Parsing of strings with Date.parse is strongly discouraged due to browser differences and inconsistencies.

Date.UTC()
Accepts the same parameters as the longest form of the constructor (i.e. 2 to 7) and returns the number of milliseconds since January 1, 1970, 00:00:00 UTC, with leap seconds ignored.

Instance methods

Date.prototype.getDate()
Returns the day of the month (131) for the specified date according to local time.
Date.prototype.getDay()
Returns the day of the week (06) for the specified date according to local time.
Date.prototype.getFullYear()
Returns the year (4 digits for 4-digit years) of the specified date according to local time.
Date.prototype.getHours()
Returns the hour (023) in the specified date according to local time.
Date.prototype.getMilliseconds()
Returns the milliseconds (0999) in the specified date according to local time.
Date.prototype.getMinutes()
Returns the minutes (059) in the specified date according to local time.
Date.prototype.getMonth()
Returns the month (011) in the specified date according to local time.
Date.prototype.getSeconds()
Returns the seconds (059) in the specified date according to local time.
Date.prototype.getTime()
Returns the numeric value of the specified date as the number of milliseconds since January 1, 1970, 00:00:00 UTC. (Negative values are returned for prior times.)
Date.prototype.getTimezoneOffset()
Returns the time-zone offset in minutes for the current locale.
Date.prototype.getUTCDate()
Returns the day (date) of the month (131) in the specified date according to universal time.
Date.prototype.getUTCDay()
Returns the day of the week (06) in the specified date according to universal time.
Date.prototype.getUTCFullYear()
Returns the year (4 digits for 4-digit years) in the specified date according to universal time.
Date.prototype.getUTCHours()
Returns the hours (023) in the specified date according to universal time.
Date.prototype.getUTCMilliseconds()
Returns the milliseconds (0999) in the specified date according to universal time.
Date.prototype.getUTCMinutes()
Returns the minutes (059) in the specified date according to universal time.
Date.prototype.getUTCMonth()
Returns the month (011) in the specified date according to universal time.
Date.prototype.getUTCSeconds()
Returns the seconds (059) in the specified date according to universal time.
Date.prototype.getYear()
Returns the year (usually 2–3 digits) in the specified date according to local time. Use getFullYear() instead.
Date.prototype.setDate()
Sets the day of the month for a specified date according to local time.
Date.prototype.setFullYear()
Sets the full year (e.g. 4 digits for 4-digit years) for a specified date according to local time.
Date.prototype.setHours()
Sets the hours for a specified date according to local time.
Date.prototype.setMilliseconds()
Sets the milliseconds for a specified date according to local time.
Date.prototype.setMinutes()
Sets the minutes for a specified date according to local time.
Date.prototype.setMonth()
Sets the month for a specified date according to local time.
Date.prototype.setSeconds()
Sets the seconds for a specified date according to local time.
Date.prototype.setTime()
Sets the Date object to the time represented by a number of milliseconds since January 1, 1970, 00:00:00 UTC. Use negative numbers for times prior.
Date.prototype.setUTCDate()
Sets the day of the month for a specified date according to universal time.
Date.prototype.setUTCFullYear()
Sets the full year (e.g. 4 digits for 4-digit years) for a specified date according to universal time.
Date.prototype.setUTCHours()
Sets the hour for a specified date according to universal time.
Date.prototype.setUTCMilliseconds()
Sets the milliseconds for a specified date according to universal time.
Date.prototype.setUTCMinutes()
Sets the minutes for a specified date according to universal time.
Date.prototype.setUTCMonth()
Sets the month for a specified date according to universal time.
Date.prototype.setUTCSeconds()
Sets the seconds for a specified date according to universal time.
Date.prototype.setYear()
Sets the year (usually 2–3 digits) for a specified date according to local time. Use setFullYear() instead.
Date.prototype.toDateString()
Returns the "date" portion of the Date as a human-readable string like 'Thu Apr 12 2018'.
Date.prototype.toISOString()
Converts a date to a string following the ISO 8601 Extended Format.
Date.prototype.toJSON()
Returns a string representing the Date using toISOString(). Intended for use by JSON.stringify().
Date.prototype.toGMTString()
Returns a string representing the Date based on the GMT (UTC) time zone. Use toUTCString() instead.
Date.prototype.toLocaleDateString()
Returns a string with a locality sensitive representation of the date portion of this date based on system settings.
Date.prototype.toLocaleFormat()
Converts a date to a string, using a format string.
Date.prototype.toLocaleString()
Returns a string with a locality-sensitive representation of this date. Overrides the Object.prototype.toLocaleString() method.
Date.prototype.toLocaleTimeString()
Returns a string with a locality-sensitive representation of the time portion of this date, based on system settings.
Date.prototype.toString()
Returns a string representing the specified Date object. Overrides the Object.prototype.toString() method.
Date.prototype.toTimeString()
Returns the "time" portion of the Date as a human-readable string.
Date.prototype.toUTCString()
Converts a date to a string using the UTC timezone.
Date.prototype.valueOf()
Returns the primitive value of a Date object. Overrides the Object.prototype.valueOf() method.

Examples

Several ways to create a Date object

The following examples show several ways to create JavaScript dates:

Note: Parsing of date strings with the Date constructor (and Date.parse, they are equivalent) is strongly discouraged due to browser differences and inconsistencies.

let today = new Date()
let birthday = new Date('December 17, 1995 03:24:00')
let birthday = new Date('1995-12-17T03:24:00')
let birthday = new Date(1995, 11, 17)            // the month is 0-indexed
let birthday = new Date(1995, 11, 17, 3, 24, 0)
let birthday = new Date(628021800000)            // passing epoch timestamp

To get Date, Month and Year or Time

let [month, date, year]    = new Date().toLocaleDateString("en-US").split("/")
let [hour, minute, second] = new Date().toLocaleTimeString("en-US").split(/:| /)

Two digit years map to 1900 – 1999

In order to create and get dates between the years 0 and 99 the Date.prototype.setFullYear() and Date.prototype.getFullYear() methods should be used.

let date = new Date(98, 1)  // Sun Feb 01 1998 00:00:00 GMT+0000 (GMT)

// Deprecated method; 98 maps to 1998 here as well
date.setYear(98)            // Sun Feb 01 1998 00:00:00 GMT+0000 (GMT)

date.setFullYear(98)        // Sat Feb 01 0098 00:00:00 GMT+0000 (BST)

Calculating elapsed time

The following examples show how to determine the elapsed time between two JavaScript dates in milliseconds.

Due to the differing lengths of days (due to daylight saving changeover), months, and years, expressing elapsed time in units greater than hours, minutes, and seconds requires addressing a number of issues, and should be thoroughly researched before being attempted.

// Using Date objects
let start = Date.now()

// The event to time goes here:
doSomethingForALongTime()
let end = Date.now()
let elapsed = end - start // elapsed time in milliseconds
// Using built-in methods
let start = new Date()

// The event to time goes here:
doSomethingForALongTime()
let end = new Date()
let elapsed = end.getTime() - start.getTime() // elapsed time in milliseconds
// To test a function and get back its return
function printElapsedTime(fTest) {
  let nStartTime = Date.now(),
      vReturn = fTest(),
      nEndTime = Date.now()

  console.log(`Elapsed time: ${ String(nEndTime - nStartTime) } milliseconds`)
  return vReturn
}

let yourFunctionReturn = printElapsedTime(yourFunction)

Note: In browsers that support the Web Performance API's high-resolution time feature, Performance.now() can provide more reliable and precise measurements of elapsed time than Date.now().

Get the number of seconds since the ECMAScript Epoch

let seconds = Math.floor(Date.now() / 1000)

In this case, it's important to return only an integer—so a simple division won't do. It's also important to only return actually elapsed seconds. (That's why this code uses Math.floor(), and not Math.round().)

Specifications

Browser compatibilityUpdate compatibility data on GitHub

Desktop
Chrome Edge Firefox Internet Explorer Opera Safari
Date 1 12 1 3
3
The ISO8601 Date Format is not supported in Internet Explorer 8 or earlier.
3 1
Date() constructor 1 12 1 3 3 1
UTC 1 12 1 3 3 1
getDate 1 12 1 3 3 1
getDay 1 12 1 3 3 1
getFullYear 1 12 1 4 4 1
getHours 1 12 1 3 3 1
getMilliseconds 1 12 1 4 4 1
getMinutes 1 12 1 4 3 1
getMonth 1 12 1 4 3 1
getSeconds 1 12 1 4 3 1
getTime 1 12 1 4 3 1
getTimezoneOffset 1 12 1 5 3 1
getUTCDate 1 12 1 4 4 1
getUTCDay 1 12 1 4 4 1
getUTCFullYear 1 12 1 4 4 1
getUTCHours 1 12 1 4 4 1
getUTCMilliseconds 1 12 1 4 4 1
getUTCMinutes 1 12 1 4 4 1
getUTCMonth 1 12 1 4 4 1
getUTCSeconds 1 12 1 4 4 1
getYear 1 12 1 3 3 1
now 5 12 3 9 10.5 4
parse 1 12 1 3 3 1
parse: ISO 8601 format 6 12 4 9 6 5.1
setDate 1 12 1 3 3 1
setFullYear 1 12 1 4 4 1
setHours 1 12 1 3 3 1
setMilliseconds 1 12 1 4 4 1
setMinutes 1 12 1 3 3 1
setMonth 1 12 1 3 3 1
setSeconds 1 12 1 3 3 1
setTime 1 12 1 3 3 1
setUTCDate 1 12 1 4 4 1
setUTCFullYear 1 12 1 4 4 1
setUTCHours 1 12 1 4 4 1
setUTCMilliseconds 1 12 1 4 4 1
setUTCMinutes 1 12 1 4 4 1
setUTCMonth 1 12 1 4 4 1
setUTCSeconds 1 12 1 4 4 1
setYear 1 12 1 3 3 1
toDateString 1 12 1 5.5 5 1
toGMTString 1 12 1 3 3 1
toISOString 3 12 1 9 10.5 5
toJSON 3 12 1 8 10.5 5
toLocaleDateString 1 12 1 5.5 5 1
toLocaleDateString: IANA time zone names in timeZone option 24 14 52 No 15 6.1
toLocaleDateString.locales 24 12 29 11 15 10
toLocaleDateString.options 24 12 29 11 15 10
toLocaleString 1 12 1 3 3 1
toLocaleString: IANA time zone names in timeZone option 24 14 52 No 15 6.1
toLocaleString.locales 24 12 29 11 15 10
toLocaleString.options 24 12 29 11 15 10
toLocaleTimeString 1 12 1 5.5 5 1
toLocaleTimeString: IANA time zone names in timeZone option 24 14 52 No 15 6.1
toLocaleTimeString.locales 24 12 29 11 15 10
toLocaleTimeString.options 24 12 29 11 15 10
toSource No No 1 — 74
1 — 74
Starting in Firefox 74, toSource() is no longer available for use by web content. It is still allowed for internal and privileged code.
No No No
toString 1 12 1 3 3 1
toTimeString 1 12 1 5.5 5 1
toUTCString 1 12 1 4 4 1
valueOf 1 12 1 4 3 1
@@toPrimitive 47 15 44 No 34 10
Mobile
Android webview Chrome for Android Firefox for Android Opera for Android Safari on iOS Samsung Internet
Date 1 18 4 10.1 1 1.0
Date() constructor 1 18 4 10.1 1 1.0
UTC 1 18 4 10.1 1 1.0
getDate 1 18 4 10.1 1 1.0
getDay 1 18 4 10.1 1 1.0
getFullYear 1 18 4 10.1 1 1.0
getHours 1 18 4 10.1 1 1.0
getMilliseconds 1 18 4 10.1 1 1.0
getMinutes 1 18 4 10.1 1 1.0
getMonth 1 18 4 10.1 1 1.0
getSeconds 1 18 4 10.1 1 1.0
getTime 1 18 4 10.1 1 1.0
getTimezoneOffset 1 18 4 10.1 1 1.0
getUTCDate 1 18 4 10.1 1 1.0
getUTCDay 1 18 4 10.1 1 1.0
getUTCFullYear 1 18 4 10.1 1 1.0
getUTCHours 1 18 4 10.1 1 1.0
getUTCMilliseconds 1 18 4 10.1 1 1.0
getUTCMinutes 1 18 4 10.1 1 1.0
getUTCMonth 1 18 4 10.1 1 1.0
getUTCSeconds 1 18 4 10.1 1 1.0
getYear 1 18 4 10.1 1 1.0
now 1 18 4 14 4 1.0
parse 1 18 4 10.1 1 1.0
parse: ISO 8601 format ≤37 18 4 10.1 5.1 1.0
setDate 1 18 4 10.1 1 1.0
setFullYear 1 18 4 10.1 1 1.0
setHours 1 18 4 10.1 1 1.0
setMilliseconds 1 18 4 10.1 1 1.0
setMinutes 1 18 4 10.1 1 1.0
setMonth 1 18 4 10.1 1 1.0
setSeconds 1 18 4 10.1 1 1.0
setTime 1 18 4 10.1 1 1.0
setUTCDate 1 18 4 10.1 1 1.0
setUTCFullYear 1 18 4 10.1 1 1.0
setUTCHours 1 18 4 10.1 1 1.0
setUTCMilliseconds 1 18 4 10.1 1 1.0
setUTCMinutes 1 18 4 10.1 1 1.0
setUTCMonth 1 18 4 10.1 1 1.0
setUTCSeconds 1 18 4 10.1 1 1.0
setYear 1 18 4 10.1 1 1.0
toDateString 1 18 4 10.1 1 1.0
toGMTString 1 18 4 10.1 1 1.0
toISOString ≤37 18 4 11 4.2 1.0
toJSON ≤37 18 4 11 4.2 1.0
toLocaleDateString 1 18 4 10.1 1 1.0
toLocaleDateString: IANA time zone names in timeZone option 4.4 25 No 14 7 1.5
toLocaleDateString.locales 4.4 25 56 14 10 1.5
toLocaleDateString.options 4.4 25 56 14 10 1.5
toLocaleString 1 18 4 10.1 1 1.0
toLocaleString: IANA time zone names in timeZone option 4.4 25 No 14 7 1.5
toLocaleString.locales 4.4 25 56 14 10 1.5
toLocaleString.options 4.4 25 56 14 10 1.5
toLocaleTimeString 1 18 4 10.1 1 1.0
toLocaleTimeString: IANA time zone names in timeZone option 4.4 25 No 14 7 1.5
toLocaleTimeString.locales 4.4 25 56 14 10 1.5
toLocaleTimeString.options 4.4 25 56 14 10 1.5
toSource No No 4 No No No
toString 1 18 4 10.1 1 1.0
toTimeString 1 18 4 10.1 1 1.0
toUTCString 1 18 4 10.1 1 1.0
valueOf 1 18 4 10.1 1 1.0
@@toPrimitive 47 47 44 34 10 5.0
Server
Node.js
Date 0.1.100
Date() constructor 0.1.100
UTC 0.1.100
getDate 0.1.100
getDay 0.1.100
getFullYear 0.1.100
getHours 0.1.100
getMilliseconds 0.1.100
getMinutes 0.1.100
getMonth 0.1.100
getSeconds 0.1.100
getTime 0.1.100
getTimezoneOffset 0.1.100
getUTCDate 0.1.100
getUTCDay 0.1.100
getUTCFullYear 0.1.100
getUTCHours 0.1.100
getUTCMilliseconds 0.1.100
getUTCMinutes 0.1.100
getUTCMonth 0.1.100
getUTCSeconds 0.1.100
getYear 0.1.100
now 0.1.100
parse 0.1.100
parse: ISO 8601 format 0.12
setDate 0.1.100
setFullYear 0.1.100
setHours 0.1.100
setMilliseconds 0.1.100
setMinutes 0.1.100
setMonth 0.1.100
setSeconds 0.1.100
setTime 0.1.100
setUTCDate 0.1.100
setUTCFullYear 0.1.100
setUTCHours 0.1.100
setUTCMilliseconds 0.1.100
setUTCMinutes 0.1.100
setUTCMonth 0.1.100
setUTCSeconds 0.1.100
setYear 0.1.100
toDateString 0.1.100
toGMTString 0.1.100
toISOString 0.1.100
toJSON 0.1.100
toLocaleDateString 0.1.100
toLocaleDateString: IANA time zone names in timeZone option 0.12
toLocaleDateString.locales 13.0.0
13.0.0
0.12
Before version 13.0.0, only the locale data for en-US is available by default. When other locales are specified, the function silently falls back to en-US. To make full ICU (locale) data available for versions prior to 13, see Node.js documentation on the --with-intl option and how to provide the data.
toLocaleDateString.options 0.12
toLocaleString 0.1.100
toLocaleString: IANA time zone names in timeZone option 0.12
toLocaleString.locales 13.0.0
13.0.0
0.12
Before version 13.0.0, only the locale data for en-US is available by default. When other locales are specified, the function silently falls back to en-US. To make full ICU (locale) data available for versions prior to 13, see Node.js documentation on the --with-intl option and how to provide the data.
toLocaleString.options 0.12
toLocaleTimeString 0.1.100
toLocaleTimeString: IANA time zone names in timeZone option 0.12
toLocaleTimeString.locales 13.0.0
13.0.0
0.12
Before version 13.0.0, only the locale data for en-US is available by default. When other locales are specified, the function silently falls back to en-US. To make full ICU (locale) data available for versions prior to 13, see Node.js documentation on the --with-intl option and how to provide the data.
toLocaleTimeString.options 0.12
toSource No
toString 0.1.100
toTimeString 0.1.100
toUTCString 0.1.100
valueOf 0.1.100
@@toPrimitive 6.0.0

See also

© 2005–2018 Mozilla Developer Network and individual contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://wiki.developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date