DEV Community

Cover image for Formatting dates and times without a library in JavaScript
Daryl Lukas
Daryl Lukas

Posted on • Edited on

Formatting dates and times without a library in JavaScript

Dates and times can be tricky in JavaScript. You always want to be sure you are doing it correctly. Luckily, because JavaScript has a built-in Date object, it makes working with dates and times much easier. In fact, there are many different methods on the Date object that can be used to do different things with dates. In this blog, I'll run through a few of these methods.

A quick note on the Date object

The built-in Date object in JavaScript offers us a set of APIs for working with date and time data. A Date object instance represents a single point in time. The instance is in a platform-independent format.

Creating an instance

Current Date / Time

There are multiple ways you can get an instance (or representation) of the current date and time.

Using the constructor

let now;

now = new Date();
console.log(now); // [object Date] { ... }
Enter fullscreen mode Exit fullscreen mode

Using the Date() function

This returns a string representation of the current date and time

now = Date();
console.log(now);
// "Mon Nov 21 2022 10:39:45 GMT+0200 (South Africa Standard Time)"
Enter fullscreen mode Exit fullscreen mode

Using a static method, .now()

This returns a number that represents the milliseconds elasped since 1 January 1970 UTC

now = Date.now();
console.log(now);
// 1669019985182
Enter fullscreen mode Exit fullscreen mode

Other ways to create an instance

Parsing strings

With the new Date() constructor (or Date.parse() ). Strings must be compliant with the ISO 8601 format, YYYY-MM-DDTHH:mm:ss.sssZ.

const nextBirthday= new Date('2023-08-02T00:00:00')
Enter fullscreen mode Exit fullscreen mode

The example below is discouraged and may not work in all runtimes/browsers. A library like moment or dayjs can help if other string formats are needed.

const nextBirthday = new Date('August 02, 2023 00:00:00');
// DISCOURAGED: may not work in all runtimes
Enter fullscreen mode Exit fullscreen mode

Passing integers in the constructor

This syntax is new Date(year, month, day, hours, minutes, seconds, milliseconds);

This month is 0-indexed, meaning 0 is January and 11 is December

nextBirthday = new Date(2023, 7, 2, 0, 0, 0);
console.log(nextBirthday .toString());
// "Wed Aug 02 2023 00:00:00 GMT+0200 (South Africa Standard Time)"
Enter fullscreen mode Exit fullscreen mode

Epoch (Unix) Timestamp

Epoch timestamp is the number of seconds elapsed since January 1, 1970 (midnight UTC/GMT)

Sytanx new Date(milliseconds)

nextBirthday = new Date(1690927200000)
Enter fullscreen mode Exit fullscreen mode

Get Epoch in seconds

const seconds = Math.floor(Date.now() / 1000);
Enter fullscreen mode Exit fullscreen mode

Date methods

We can also manage and manipulate dates and times using the methods provided by the Date object.

Accessing Date components

Get the year (4 digits, e.g., 2022)

nextBirthday.getFullYear()
// 2023
Enter fullscreen mode Exit fullscreen mode

Get the month. The month is zero-indexed (i.e., 0 - 11).

nextBirthday.getMonth()
// 7
Enter fullscreen mode Exit fullscreen mode

Get the day of the month, from 1 to 31.

nextBirthday.getDate()
// 2
Enter fullscreen mode Exit fullscreen mode

Get the day of the week. This is also zero-index (i.e., from 0 to 6). The first day is always Sunday, 0 and last day is Saturday, 6. (Not so in some countries but can’t be changed).

nextBirthday.getDay();
// 2
Enter fullscreen mode Exit fullscreen mode

The methods, getHours(), getMinutes(), getSeconds() , getMilliseconds() get the corresponding time components.

All the methods above return the components relative to your local time zone. UTC-counterparts are available for each method which return values relative to UTC. Simply insert UTC right after get in the method name.

// Local time is UTC +2
nextBirthday.getHours(); // 0
nextBirthday.getUTCHours(); // 22
Enter fullscreen mode Exit fullscreen mode

Destructuring assignment example

const date = new Date();
const [month, day, year] = [date.getMonth(), date.getDate(), date.getFullYear()];
const [hour, minutes, seconds] = [date.getHours(), date.getMinutes(), date.getSeconds()];
Enter fullscreen mode Exit fullscreen mode

Setting Date Components

The following methods allow to set date/time components

  • setFullYear(year, [month], [date])
  • setMonth(month, [date])
  • setDate(date)
  • setHours(hour, [min], [sec], [ms])
  • setMinutes(min, [sec], [ms])
  • setSeconds(sec, [ms])
  • setMilliseconds(ms)
  • setTime(milliseconds) (sets the whole date by milliseconds since 01.01.1970 UTC)
let now = new Date();
now.setHours(12);
now.setFullYear(2015);
console.log(now.toString());
// "Sat Nov 21 2015 12:08:53 GMT+0200 (South Africa Standard Time)"
Enter fullscreen mode Exit fullscreen mode

Every one of them except setTime() has a UTC-variant

let now = new Date();
now.setUTCHours(2);
Enter fullscreen mode Exit fullscreen mode

Some methods can set multiple components at once. For example, setHours() gives you the option to set minutes, seconds and milliseconds as well. These options are not modified if not included in the method call.

let today = new Date();

today.setHours(12);
console.log(now.toString());
// "Mon Nov 21 2022 12:13:36 GMT+0200 (South Africa Standard Time)"

now.setHours(12, 12, 12, 12);
console.log(now.toString());
// "Mon Nov 21 2022 12:12:12 GMT+0200 (South Africa Standard Time)"
Enter fullscreen mode Exit fullscreen mode

Formatting

Variations of the toString() method. Returns various string representation of a Date instance.

let now = new Date();

now.toString();
// "Mon Nov 21 2022 14:17:21 GMT+0200 (South Africa Standard Time)"

now.toDateString();
// "Mon Nov 21 2022"

now.toTimeString();
// "14:17:21 GMT+0200 (South Africa Standard Time)"

now.toISOString();
// "2022-11-21T12:17:21.595Z"

now.toUTCString();
// "Mon, 21 Nov 2022 12:17:21 GMT"

now.toLocaleString();
// "11/21/2022, 2:17:21 PM"

now.toLocaleDateString();
// "11/21/2022"

now.toLocaleTimeString();
// "2:17:21 PM"

now.toJSON();
// "2022-11-21T12:17:21.595Z"
Enter fullscreen mode Exit fullscreen mode

The Intl.DateTimeFormat object

On modern browsers and runtimes, JavaScript includes an Internationalization API that allows for language-sensitive date and time formatting. You can start using it right away without having to import a massive date formatting library.

const now = new Date();

const formatted1 = Intl.DateTimeFormat('en-ZM').format(now);
const formatted2 = Intl.DateTimeFormat('en-ZM', { dateStyle: "full" }).format(now);
const formatted3 = Intl.DateTimeFormat('en-ZM', { dateStyle: "long" }).format(now);
const formatted4 = Intl.DateTimeFormat('en-ZM', { dateStyle: "medium" }).format(now);
const formatted5 = Intl.DateTimeFormat('en-ZM', { dateStyle: "short" }).format(now);

console.log(now); // [object Date] ...
console.log(formatted1); // "21/11/2022"
console.log(formatted2); // "Monday, November 21, 2022"
console.log(formatted3); // "21 November 2022"
console.log(formatted4); // "21 Nov 2022"
console.log(formatted5); // "21/11/2022"
Enter fullscreen mode Exit fullscreen mode

Conclusion

In today's blog post, we learned how to format date/time data in JavaScript. There are many libraries that handle this for us already, but if you're working in a legacy codebase or have performance reasons for wanting to avoid a library, you may have to handle date/time formatting natively.

Learn more about the Date object on MDN references docs

Top comments (0)