Photo by Ben Griffiths on Unsplash
Introduction
PHP 8.4 is set to be released in November 2024 and will introduce some handy new array functions:
-
array_find
-
array_find_key
-
array_any
-
array_all
In this article, we're going to take a quick look at these new functions and how you'll be able to use them in your projects running PHP 8.4.
If you're a Laravel developer, you might notice that we already have similar functions in the Illuminate\Support\Collection
and Illuminate\Support\Arr
classes. But I love that these functions will be native to PHP and so will be available in any PHP project.
For any of my readers who are Laravel developers, I'll show you the Laravel equivalents of these new functions so that you can achieve the same functionality in your Laravel projects without having to wait for PHP 8.4.
You might also be interested in checking out my other article that talks all about PHP 8.4's new "property hooks" feature.
The array_find
function
The array_find
function returns the value of the first element that matches the criteria defined in the callback. If no element matches the callback, the function returns null
.
Let's take a look at a simple example. We'll imagine we have an array of products and that we want to find the product with a barcode of 123456
:
$products = [
[
'name' => 'Macbook Pro',
'type' => 'Laptop',
'barcode' => 123456,
],
[
'name' => 'Framework Laptop 13',
'type' => 'Laptop',
'barcode' => 789012,
],
[
'name' => 'Samsung Galaxy S24',
'type' => 'Phone',
'barcode' => 135791,
],
];
// Find the product with barcode 123456
$findProduct = array_find(
array: $products,
callback: function (array $product): bool {
return $product['barcode'] == 123456;
},
);
After running the code above, $findProduct
will be equal to:
[
'name'=> 'Macbook Pro',
'type' => 'Laptop',
'barcode' => 123456,
]
We could clean this up a little further by using an arrow function as the second argument:
$findProduct = array_find(
array: $products,
callback: fn (array $product): bool => $product['barcode'] === 123456,
);
The above code will return the same result as the previous example.
If no element matches the callback, the function will return null
. Let's see an example of this:
$nonExistentProduct = array_find(
array: $products,
callback: fn (array $product): bool => $product['barcode'] === 'invalid',
);
In this case, $nonExistentProduct
will be equal to null
.
Laravel Equivalent
In Laravel, you can achieve a similar result using the Arr::first
method:
use Illuminate\Support\Arr;
$findProduct = Arr::first(
$products,
fn (array $product): bool => $product['barcode'] === 123456,
);
The array_find_key
function
This function is similar to the array_find
function, but instead of returning the value of the first element that matches the callback, it returns the key of the first element that matches the callback.
Let's take our $products
example array from earlier. This time, we want to find the key of the product with a barcode of 789012
:
$products = [
[
'name' => 'Macbook Pro',
'type' => 'Laptop',
'barcode' => 123456,
],
[
'name' => 'Framework Laptop 13',
'type' => 'Laptop',
'barcode' => 789012,
],
[
'name' => 'Samsung Galaxy S24',
'type' => 'Phone',
'barcode' => 135791,
],
];
// Find the key of the product with barcode 789012
$findProduct = array_find_key(
array: $products,
callback: fn (array $product): bool => $product['barcode'] === 789012,
);
After running the code above, $findProduct
will be equal to 1
because the product is the second element in the array.
If no element matches the callback, the function will return null
. Let's see an example of this:
$nonExistentProduct = array_find_key(
array: $products,
callback: fn (array $product): bool => $product['barcode'] === 'invalid',
);
In this case, $nonExistentProduct
will be equal to null
.
Laravel Equivalent
In Laravel, you can achieve a similar result using a combination of the array_keys
and Arr::first
methods:
use Illuminate\Support\Arr;
$firstProductKey = Arr::first(
array_keys($products),
fn (int $key): bool => $products[$key]['barcode'] === 789012,
);
In the code above, we're first using array_keys
to get an array of the keys of the $products
array. We then use Arr::first
to find the first key that matches the callback. This is a little more verbose than the native PHP function, but it achieves the same result.
The array_any
function
The array_any
function allows you to check that at least one element in the array matches the criteria defined in the callback. If any element matches the callback, the function returns true
. If no element matches the callback, the function returns false
.
Sticking with our $products
example array, let's check if any of the products have a type of Laptop
:
$anyProductsAreLaptops = array_any(
array: $products,
callback: fn (array $product): bool => $product['type'] === 'Laptop',
);
In this case, $anyProductsAreLaptops
will be equal to true
because at least one of the products in the array is a laptop.
If no element matches the callback, the function will return false
. Let's see an example of this:
$anyProductsAreInvalid = array_any(
array: $products,
callback: fn (array $product): bool => $product['type'] === 'Invalid',
);
In this case, $anyProductsAreInvalid
will be equal to false
.
Laravel Equivalent
We can achieve the same result in Laravel using the contains
method on a collection:
use Illuminate\Support\Collection;
$anyProductsAreLaptops = Collection::make($products)->contains(
fn (array $product): bool => $product['type'] === 'Laptop',
);
In the code above, we're creating a collection from the $products
array and then using the contains
method to check if any of the products in the collection are laptops.
The array_all
function
The array_all
function is similar to the array_any
function, but instead of checking if at least one element matches the callback, it checks if all elements match the callback. If all elements match the callback, the function returns true
. If any element does not match the callback, the function returns false
.
Let's check if all of the products in our $products
array are laptops:
$allProductsAreLaptops = array_all(
array: $products,
callback: fn (array $product): bool => $product['type'] === 'Laptop',
);
In this case, $allProductsAreLaptops
will be equal to false
because not all of the products in the array are laptops.
Laravel Equivalent
In Laravel, we can achieve the same result using the every
method on a collection:
use Illuminate\Support\Collection;
$allProductsAreLaptops = Collection::make($products)->every(
fn (array $product): bool => $product['type'] === 'Laptop',
);
In the code above, we're creating a collection from the $products
array and then using the every
method to check if all the products in the collection are laptops.
Conclusion
Hopefully, this article has shown you how you can use the new array functions that will be available in PHP 8.4. It should have also given you an idea of how you can achieve similar functionality in Laravel using the Illuminate\Support\Collection
and Illuminate\Support\Arr
classes.
If you enjoyed reading this post, you might be interested in checking out my 220+ page ebook "Battle Ready Laravel" which covers similar topics in more depth.
Or, you might want to check out my other 440+ page ebook "Consuming APIs in Laravel" which teaches you how to use Laravel to consume APIs from other services.
If you're interested in getting updated each time I publish a new post, feel free to sign up for my newsletter.
Keep on building awesome stuff! 🚀
driesvints, alexigallegos liked this article
Other articles you might like
Laravel Custom Query Builders Over Scopes
Hello 👋 Alright, let's talk about Query Scopes. They're awesome, they make queries much easier to r...
Access Laravel before and after running Pest tests
How to access the Laravel ecosystem by simulating the beforeAll and afterAll methods in a Pest test....
🍣 Sushi — Your Eloquent model driver for other data sources
In Laravel projects, we usually store data in databases, create tables, and run migrations. But not...
The Laravel portal for problem solving, knowledge sharing and community building.
The community