JavaScript ZonedDateTime withTimeZone()
Example
const zoned = Temporal.ZonedDateTime.from("2026-05-17T14:30:00[Europe/Oslo]");
let date = zoned.withTimeZone("America/New_York");
Try it Yourself »
Description
The withTimeZone() method returns a new ZonedDateTime object
with this ZonedDateTime in another time zone.
The withTimeZone() method does not change the original ZonedDateTime.
Syntax
zoneddatetime.withTimeZone(timezone)
Parameters
| Parameter | Description |
| timezone | Another ZonedDateTime or a string representing a time zone. |
Return Value
| Type | Description |
| Object | A new Temporal.ZonedDateTime object with a new time zone. |
Browser Support
Temporal is a major update to the JavaScript standard (TC39).
It is currently fully supported in Chrome, Edge, and Firefox, and is expected to reach full availability across browsers before the summer of 2026.
| Chrome 144 |
Edge 144 |
Firefox 139 |
Safari |
Opera |
| Jan 2026 | Jan 2026 | May 2025 | 🚫 | 🚫 |
Opera and Safari Support
Opera support will probably appear 1-3 browser cycles after Chromium, which often means a few months later.
The implementation is actively in development and can be tested today in Safari Technology Preview by enabling the --use-temporal runtime flag.
Polyfill
Until Opera and Safari supports Temporal natively, you can use the official polyfill:
<script
src="https://cdn.jsdelivr.net/npm/@js-temporal/polyfill/dist/index.umd.js">
</script>