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 IlluminateSupportCollection and IlluminateSupportArr 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! ?
The above is the detailed content of New Array Functions in PHP. For more information, please follow other related articles on the PHP Chinese website!

AwebserverlikeNginxorApachehandlesHTTPrequests,servesstaticfiles,managesvirtualhosts,androutesdynamicrequeststoPHP-FPM.2.PHP-FPMexecutesPHPscripts,managesworkerprocesses,andreturnsgeneratedcontenttothewebserver.3.Theyworktogetherbyhavingthewebserverf

This article aims to address the problem of percentage commission or surcharge calculation errors commonly found in programming, especially when commissions need to be added to the base price. By analyzing the error calculation logic, we provide correct mathematical principles and corresponding PHP code implementations to ensure that the calculation of the total amount and installment amount is accurate, and emphasize the data type and accuracy issues that should be paid attention to when dealing with percentage calculations to avoid common financial calculation traps.

yieldfrominPHPdelegatesgenerationtoanothergenerator,iterable,ortraversableobject,enablingcleancompositionandreuseofgeneratorlogic;1.Ititeratesovertheprovidediterableandyieldseachvalueindividually,asifproducedbythecallinggenerator;2.Itworkswithgenerat

This tutorial explains in detail the effective way to reorganize array elements in PHP based on specific string conditions. Data classification can be achieved clearly and efficiently by first merging the original array, then traversing the merged collection, and using conditional logic to assign elements to a new target array, such as grouping words containing specific letters into one class and the rest into another, ensuring the simplicity and maintainability of the code.

This article introduces how to implement the function of cumulative shopping cart product count in Laravel's updateOrCreate method. By using the DB::raw and IFNULL functions, the price field is empty when creating a new cart entry, ensuring that prices are accumulated correctly. This article provides detailed code examples and explanations to help developers easily implement shopping cart functions.

To effectively delete elements in PHP multi-dimensional arrays, you must select the appropriate method according to the specific situation: 1. When you know the exact key path, use unset() to delete it directly, but use isset() to check whether the key exists to avoid warnings; 2. When it is necessary to delete according to the value, use recursive functions to traverse the array, match and remove the specified value, and selectively clean the empty sub-array; 3. When deleting according to the conditions, use recursive combined with callback functions to achieve flexible filtering, such as deleting all sub-arrays that meet specific structure or field conditions; 4. After deleting the numerical index elements, you should call array_values() to re-index to maintain continuity; 5. Avoid directly modifying the array during traversal and causing skipped elements, and you should delay the delay through reference operations or collecting keys to be deleted.

This article will guide you on how to create a full-width page template in WordPress and resolve possible sidebar conflict issues. By modifying the page template code, ensure that the page content occupies the entire browser width, thereby achieving a true full-width layout. The point is to check and remove unnecessary sidebar calls from the template file to ensure the purity of the page layout.

This article aims to solve the problem encountered when using Ajax to get specific values from a set of dynamically generated hidden input boxes. Generate unique IDs by modifying the PHP code and accurately locate the target input box using the jQuery selector, thus ensuring that Ajax can correctly obtain the value of the hidden input box associated with the click button. At the same time, a simpler solution is provided, directly storing the ID in the link, simplifying the jQuery code.


Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.