How to Access Object Properties and Methods With JavaScript Optional Chaining?

You can use optional chaining (?.) to access object properties or methods (that could potentially be a nullish value) in the following ways:

#Using the Dot Notation

The dot notation has the following syntax for accessing object property or method:

// ES11+
obj?.prop
obj.method?.(args)

It returns undefined if the left operand evaluates to a nullish value.

You can use the dot notation as long as the property name does not have a space or a hyphen, starts with a number or is dynamically determined. For example:

// ES11+
// ...
const authorName = post?.author?.name;
const result = post.callback?.();
// ...

#Using the Bracket Notation

The bracket notation has the following syntax for accessing object property or method:

// ES11+
obj?.['prop']
obj.['prop'].method?.(args)

It returns undefined if the left operand evaluates to a nullish value.

When/if a property name has a space or a hyphen, starts with a number or is dynamically determined, it can only be accessed using the bracket notation. For example:

// ES11+
const post = posts?.[0];
const authorName = post?.['author-name'];
// ...

You can also use it in place of the dot notation. However, the dot notation has a simpler syntax and should generally be preferred wherever possible.


This post was published by Daniyal Hamid. Daniyal currently works as the Head of Engineering in Germany and has 20+ years of experience in software engineering, design and marketing. Please show your love and support by sharing this post.