Using the Laravel Optional Helper and the New Optional Closure

Using the Laravel Optional Helper and the New Optional Closure

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:

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.

Filed in: Laravel Tutorials


Join 31,000+ others and never miss out on new tips, tutorials, and more.

Laravel News Partners

Laravel Jobs

Software Developer
Remote (US & Canada)
😎 Laravel Developer
Jogg, Inc
Junior, Mid, and Senior Software Engineers. Laravel / Vue. Saint Petersburg, FL
Saint Petersburg, FL and Remote
Senior PHP Developer (Laravel)
The Interaction Design Foundation
Fullstack Laravel Engineer (Munich/Remote) 💻
Munich, Germany or Remote