Support the ongoing development of Laravel.io →
Article Hero Image

New Array Functions in PHP 8.4

19 Aug, 2024 6 min read

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! 🚀

Last updated 3 weeks ago.

driesvints, alexigallegos liked this article

2
Like this article? Let the author know and give them a clap!
ash-jc-allen (Ash Allen) I'm a freelance Laravel web developer from Preston, UK. I maintain the Ash Allen Design blog and get to work on loads of cool and exciting projects 🚀

Other articles you might like

Article Hero Image November 18th 2024

Laravel Custom Query Builders Over Scopes

Hello 👋 Alright, let's talk about Query Scopes. They're awesome, they make queries much easier to r...

Read article
Article Hero Image November 19th 2024

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....

Read article
Article Hero Image November 11th 2024

🍣 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...

Read article

We'd like to thank these amazing companies for supporting us

Your logo here?

Laravel.io

The Laravel portal for problem solving, knowledge sharing and community building.

© 2024 Laravel.io - All rights reserved.