Convert datetime from UTC to local timezone and vice-versa using Vanilla JavaScript, Day.js and Luxon
— Web Development, Day.js, Luxon — 3 min read
A very common scenario we face when working with modern web applications is to convert UTC datetime values coming from the server in ISO 8601 format into local datetime values and then changing it back to UTC ISO-8601 while sending data back to the server.
In this article, we'll look at three different approaches to convert datetime values from UTC to local and vice versa using Vanilla JavaScript or by using popular libraries such as Day.js and Luxon.
Convert UTC to local and vice-versa using Vanilla JavaScript
We can use the constructor new Date() to convert a UTC datetime value in ISO 8601 format into a local timezone datetime value and .toISOString() to convert a local datetime value to a UTC string.
/* UTC TO LOCAL */var strUTC = ( new Date() ).toISOString();console.log( strUTC ); // 2024-03-01T17:57:50.646Zvar datetimeLocal = new Date( strUTC );console.log( datetimeLocal.toLocaleString() ); // 1/3/2024, 11:27:50 pm
/* LOCAL TO UTC */var datetimeLocal = new Date();console.log( datetimeLocal.toLocaleString() ); // 1/3/2024, 11:27:50 pmvar strUTC = datetimeLocal.toISOString();console.log( strUTC ); // 2024-03-01T17:57:50.646ZThere are some potential disadvantages to using this approach as discussed in the comments of this SO answer. Basically, the new Date() constructor behaves differently across different browser implementations.
Convert UTC to local and vice-versa using Day.js
With Day.js, we can convert a UTC datetime value to local using the local() method. For converting a local datetime value to UTC, we can use the utc() method. Both these methods use the utc plugin.
Day.js also exposes the toISOString() method that provides a quick alternative to convert a local datetime value to a ISO-8601 UTC datetime string.
import dayjs from "dayjs";import utc from "dayjs/plugin/utc";
dayjs.extend(utc);
/* UTC TO LOCAL */var datetimeUTC = dayjs().utc();console.log( datetimeUTC.format() ); // 2024-03-01T13:42:51Zvar datetimeLocal = datetimeUTC.local();console.log( datetimeLocal.format() ); // 2024-03-01T19:12:51+05:30
/* LOCAL TO UTC */var datetimeLocal = dayjs();console.log( datetimeLocal.format() ); // 2024-03-01T19:22:47+05:30console.log( datetimeLocal.toISOString() ); // 2024-03-01T13:52:47.082Zvar datetimeUTC = datetimeLocal.utc();console.log( datetimeUTC.format() ); // 2024-03-01T13:52:47ZConvert UTC to local and vice-versa using Luxon
With Luxon, we can convert a UTC datetime value to local using the toLocal() method. For converting a local datetime value to UTC, we can use the toUTC() method.
Luxon also exposes the toISO() method that formats the datetime value into an ISO 8601 string.
import { DateTime } from "luxon";
/* UTC TO LOCAL */var datetimeUTC = DateTime.utc();console.log( datetimeUTC.toISO() ); // 2024-03-01T14:04:38.363Zvar datetimeLocal = datetimeUTC.toLocal();console.log( datetimeLocal.toISO() ); // 2024-03-01T19:34:38.363+05:30
/* LOCAL TO UTC */var datetimeLocal = DateTime.local();console.log( datetimeLocal.toISO() ); // 2024-03-01T19:34:38.363+05:30var datetimeUTC = datetimeLocal.toUTC();console.log( datetimeUTC.toISO() ); // 2024-03-01T14:04:38.363ZWhat about Moment.js?
The official Moment.js site recommends using other libraries like Luxon and Day.js for new projects because of various reasons which is why I have not included snippets that use Moment.js.
Summary
This tutorial explains how we can convert a UTC datetime value to local and vice-versa using either vanilla JavaScript or populat libraries like Luxon and Day.js. You can choose one that best suits your project requirements.
Hope this helps!🙏