New Array Functions in PHP 8.4

ashallendesign

Ash Allen

Posted on August 19, 2024

New Array Functions in PHP 8.4

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;
    },
);
Enter fullscreen mode Exit fullscreen mode

After running the code above, $findProduct will be equal to:

[
    'name'=> 'Macbook Pro',
    'type' => 'Laptop',
    'barcode' => 123456,
]
Enter fullscreen mode Exit fullscreen mode

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,
);
Enter fullscreen mode Exit fullscreen mode

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',
);
Enter fullscreen mode Exit fullscreen mode

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,
);
Enter fullscreen mode Exit fullscreen mode

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,
);
Enter fullscreen mode Exit fullscreen mode

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',
);
Enter fullscreen mode Exit fullscreen mode

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,
);
Enter fullscreen mode Exit fullscreen mode

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',
);
Enter fullscreen mode Exit fullscreen mode

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',
);
Enter fullscreen mode Exit fullscreen mode

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',
);
Enter fullscreen mode Exit fullscreen mode

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',
);
Enter fullscreen mode Exit fullscreen mode

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',
);
Enter fullscreen mode Exit fullscreen mode

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

💖 💪 🙅 🚩
ashallendesign
Ash Allen

Posted on August 19, 2024

Join Our Newsletter. No Spam, Only the good stuff.

Sign up to receive the latest update from our blog.

Related