Using the Laravel Optional Helper and the New Optional Closure

Published on by

Using the Laravel Optional Helper and the New Optional Closure image

The Laravel Optional class and accompanying optional helper were introduced in Laravel 5.5. This class is useful to avoid those pesky Trying to get property of non-object errors in your code.

Joseph Sibler submitted an improvement to the Laravel optional helper that we covered in Laravel 5.6.13 which now allows a closure that is only called when the object is not null:

???? The "optional" helper in @laravelphp is great for safely calling a method on an object that could be null. But what if the method is not on the actual object itself?

Well now you can pass in a closure to "optional", and it'll only call it if the given object is not null ???? pic.twitter.com/0RIbUffuOY

— Joseph Silber (@joseph_silber) April 5, 2018

His example demonstrates how the usage of the optional() helper differs slightly for use-cases where you want data from another source, but only in the case of a non-null value:

return optional(User::find($id), function ($user) {
return TwitterApi::findUser($user->twitter_id);
});

Optional vs Null Coalesce

We recently wrote about updating your Blade templates to the PHP7 null coalesce operator in preparation for Laravel 5.7, but clearly the optional() still has a place, especially for more advanced needs where you can cleanly only access the data you desire if the value isn’t null.

So when do you need the optional() or the null coalesce operator?

If you only care about returning null when a value doesn’t exist, optional is not redundant:

// null coalesce
return $user->profile->twitter_id ?? null;
 
// optional
return optional($user->profile)->twitter_id;

The two code examples accomplish the same thing. However, you must explicitly return null and use null coalesce to avoid an Undefined property notice, and the second example shows intent that the value is optionally available.

If you want a default value, null coalesce is a better choice:

return $user->profile->nickname ?? randomNickname();

The goal of the optional is to return null and avoid non-object errors in the process, without verbose code to check the object.

Learn More

We wrote about Five Laravel Helpers to Make Your Life Easier which includes the optional helper, and other useful helpers that might be helpful (pun intended).

If you want inspiration from other sources about the concept of optional, an Optional class exists in Java (introduced in Java 8), which can be used to avoid null pointer exceptions. The Java Optional API has some interesting methods you might want to explore.

Paul Redmond photo

Staff writer at Laravel News. Full stack web developer and author.

Cube

Laravel Newsletter

Join 40k+ other developers and never miss out on new tips, tutorials, and more.

image
Laravel Forge

Easily create and manage your servers and deploy your Laravel applications in seconds.

Visit Laravel Forge
Laravel Forge logo

Laravel Forge

Easily create and manage your servers and deploy your Laravel applications in seconds.

Laravel Forge
Tinkerwell logo

Tinkerwell

The must-have code runner for Laravel developers. Tinker with AI, autocompletion and instant feedback on local and production environments.

Tinkerwell
No Compromises logo

No Compromises

Joel and Aaron, the two seasoned devs from the No Compromises podcast, are now available to hire for your Laravel project. ⬧ Flat rate of $7500/mo. ⬧ No lengthy sales process. ⬧ No contracts. ⬧ 100% money back guarantee.

No Compromises
Kirschbaum logo

Kirschbaum

Providing innovation and stability to ensure your web application succeeds.

Kirschbaum
Shift logo

Shift

Running an old Laravel version? Instant, automated Laravel upgrades and code modernization to keep your applications fresh.

Shift
LoadForge logo

LoadForge

Easy, affordable load testing and stress tests for websites, APIs and databases.

LoadForge
Paragraph logo

Paragraph

Manage your Laravel app as if it was a CMS – edit any text on any page or in any email without touching Blade or language files.

Paragraph
Lucky Media logo

Lucky Media

Bespoke software solutions built for your business. We ♥ Laravel

Lucky Media
Lunar: Laravel E-Commerce logo

Lunar: Laravel E-Commerce

E-Commerce for Laravel. An open-source package that brings the power of modern headless e-commerce functionality to Laravel.

Lunar: Laravel E-Commerce
Bacancy - Staff Augmentation logo

Bacancy - Staff Augmentation

Leave your web app development hustles to the leading IT Staff Augmentation Service Providers. Choose from an extensive pool of 1050+ developers and give yourself the sigh of success you deserve with Bacancy. Get In Touch Today!

Bacancy - Staff Augmentation
DocuWriter.ai logo

DocuWriter.ai

Save hours of manually writing Code Documentation, Comments & DocBlocks, Test suites and Refactoring.

DocuWriter.ai
Rector logo

Rector

Your partner for seamless Laravel upgrades, cutting costs, and accelerating innovation for successful companies

Rector

The latest

View all →
October CMS v3.6 Ships Today, Full of New Features image

October CMS v3.6 Ships Today, Full of New Features

Read article
Laracon EU Videos are now out image

Laracon EU Videos are now out

Read article
Use Google's Gemini AI in Laravel image

Use Google's Gemini AI in Laravel

Read article
PhpStorm is getting a brand new terminal image

PhpStorm is getting a brand new terminal

Read article
Six Essential Plugins for Visual Studio Code image

Six Essential Plugins for Visual Studio Code

Read article
Modularize Your Laravel Application With the Modular Package image

Modularize Your Laravel Application With the Modular Package

Read article