This feature is not Baseline because it does not work in some of the most widely-used browsers.
The startOfDay() method of Temporal.ZonedDateTime instances returns a Temporal.ZonedDateTime object representing the first instant of this date in the time zone. It usually has a time of 00:00:00, but may be different if the midnight doesn't exist due to offset changes, in which case the first time that exists is returned.
It is equivalent to calling withPlainTime() with no arguments.
startOfDay()
None.
A Temporal.ZonedDateTime object with instant t, such that:
t is different from the date one nanosecond before t.t is the same as the date of this.// In the US, DST transitions happen at 2am, so the midnight exists const dt = Temporal.ZonedDateTime.from( "2024-03-10T12:00:00-04:00[America/New_York]", ); console.log(dt.startOfDay().toString()); // "2024-03-10T00:00:00-05:00[America/New_York]" // In Brazil, DST transitions happened at midnight, so the midnight didn't exist const dt2 = Temporal.ZonedDateTime.from( "2015-10-18T12:00-02:00[America/Sao_Paulo]", ); console.log(dt2.startOfDay().toString()); // "2015-10-18T01:00:00-02:00[America/Sao_Paulo]"
| Desktop | Mobile | Server | |||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | Bun | Deno | Node.js | |
startOfDay |
144 | 144 | 139 | No | No | 144 | 139 | No | No | No | 144 | No | ? | 1.40 | No |
Temporal.ZonedDateTimeTemporal.ZonedDateTime.prototype.with()Temporal.ZonedDateTime.prototype.add()Temporal.ZonedDateTime.prototype.subtract()Temporal.ZonedDateTime.prototype.hourTemporal.ZonedDateTime.prototype.hoursInDayTemporal.ZonedDateTime.prototype.timeZoneIdTemporal.ZonedDateTime.prototype.getTimeZoneTransition()
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Temporal/ZonedDateTime/startOfDay