Understand Arrays in PHP

* { box-sizing: border-box; } body {margin: 0;}

In this post, you’ll learn the basics of arrays in PHP. You’ll learn how to create an array and how to use associative and multidimensional arrays, and you’ll see lots of examples of arrays in action.

What Is an Array?

In PHP, an array is a data structure which allows you to store multiple elements in a single variable. These elements are stored as key-value pairs. In fact, you can use an array whenever there’s a need to store a list of elements. More often than not, all the items in an array have similar data types.

For an example, let’s say you want to store fruit names. Without an array, you would end up creating multiple variables to store the different fruit names. On the other hand, if you use an array to store fruit names, it might look like this:

As you can see, we’ve used the $array_fruits variable to store the different fruit names. One great thing about this approach is that you can add more elements to the $array_fruits array variable later on.

There are plenty of ways to manipulate values in the array variable—we’ll explore these in the later part of this article.

How to Initialize an Array

In this section, we’ll explore how to initialize an array variable and add values in that variable.

When it comes to array initialization, there are a few different ways. In most cases, it’s the array() language construct which is used to initialize an array.

In the above snippet, the $array variable is initialized with a blank array.

As of PHP 5.4, you can also use the following syntax to initialize an array.

Now, let’s see how to add elements to an array.

The above snippet should produce the following output:

The important thing to note here is that an array index starts with 0. Whenever you add a new element to an array without specifying an index, the array assigns an index automatically.

Of course, you can also create an array already initialized with values. This is the most concise way to declare an array if you already know what values it will have.

How to Access Array Elements

In the previous section, we discussed how to initialize an array variable. In this section, we’ll explore a few different ways to access array elements.

The first obvious way to access array elements is to fetch them by the array key or index.

The above snippet should produce the following output:

A cleaner way to write the code above is to use a foreach loop to iterate through the array elements.

The above snippet should produce the same output, and it takes much less code.

Similarly, you can also use the for loop to go through the array elements.

Here, we’re using the for loop to go through each index in the array and then echoing the value stored in that index. In this snippet, we’ve introduced one of the most important functions you’ll end up using while working with arrays: count. It’s used to count how many elements are in an array.

Types of Arrays in PHP

In this section, we’ll discuss the different types of array you can use in PHP.

Numerically Indexed Arrays

An array with the numeric index falls in the category of an indexed array. In fact, the examples we’ve discussed so far in this article are indexed arrays.

The numeric index is assigned automatically when you don’t specify it explicitly.

In the above example, we don’t specify an index for each item explicitly, so it’ll be initialized with the numeric index automatically.

Of course, you can also create an indexed array by using the numeric index, as shown in the following snippet.

It is also possible to have arrays with numeric keys which are not sequential or start from zero like the following example:

Don’t rely on an unknown array to have sequential numeric keys unless you explicitly set its keys to be that way.

Associative Arrays

An associate array is similar to an indexed array, but you can use string values for array keys.

Let’s see how to define an associative array.

Alternatively, you can use the following syntax as well.

To access values of an associative array, you can use either the index or the foreach loop.

As you can see, here we got the name by querying it directly, and then we used the foreach loop to get all the key-value pairs in the array.

Multidimensional Arrays

In the examples we’ve discussed so far, we’ve used scalar values as array elements. In fact, you can even store arrays as elements within other arrays—this is a multidimensional array.

Let’s look at an example.

As you can see, the hobbies key in the $employee array holds an array of hobbies. In the same way, the profiles key holds an associative array of the different profiles.

Let’s see how to access values of a multidimensional array.

As you can see, the elements of a multidimensional array can be accessed with the index or key of that element in each array part.

Unpacking Arrays

Starting from version 7.4, PHP has added the ability to expand arrays in place using the spread (...) operator. 

Initially, we could only unpack arrays with numeric keys. However, PHP 8.1 came with support for unpacking arrays with string keys. Here are some examples:

You should note that array unpacking in this manner results in overwriting existing values stored in string-based keys while numeric keys simply get renumbered. Unpacking $user_colors before $default_colors in the above example would have set the value of the body key to "red" in the $theme_colors array.

Some Useful Array Functions

In this section, we’ll go through a handful of useful array functions that are used frequently for array operations.

The count() Function

The count() function is used to count the number of elements in an array. This is often useful if you want to iterate an array with a for loop.

However, you should be careful when looping over an array with a for loop. This is because there is no guarantee that the numeric keys in an array will always be sequential, start from zero or be in simple ascending order.

The is_array() Function

This is one of the most useful functions for dealing with arrays. It’s used to check if a variable is an array or some other data type.

You should always use this function before you perform any array operation if you’re uncertain of the data type.

The in_array() Function

If you want to check if an element exists in the array, it’s the in_array() function which comes to the rescue.

The first argument of the in_array() function is an element which you want to check, and the second argument is the array itself.

The explode() Function

The explode() function splits a string into multiple parts and returns it as an array. For example, let’s say you have a comma-separated string and you want to split it at the commas.

The first argument of the explode() function is a delimiter string (the string you’re splitting on), and the second argument is the string itself.

The implode() Function

This is the opposite of the explode() function—given an array and a glue string, the implode() function can generate a string by joining all the elements of an array with a glue string between them.

The first argument of the implode() function is a glue string, and the second argument is the array to implode.

The array_push() Function

The array_push() function is used to add new elements to the end of an array.

The first argument is an array, and the subsequent arguments are elements that will be added to the end of an array.

The array_pop() Function

The array_pop() function removes an element from the end of an array.

The array_pop() function returns the element which is removed from an array, so you can pull it into the variable. Along with array_push(), this function is useful for implementing data structures like stacks.

The array_slice() Function

The array_slice() function is useful when you want to extract some portion of a given array. It accepts four parameters: the array, the index from which to slice, the number of elements to slice, and whether to preserve numerical key. The function will always preserve string keys irrespective of the fourth parameter.

The offset value can also be negative. In that case, the slicing position will be determined from the end of the array.

The array_splice() Function

Th array_splice() function is useful when you want to either get rid of a portion of an array and/or replace it with something else. It also accepts four parameters: the array, the offset index from which to begin the removal, the length to remove, and an optional replacement for the removed values.

Conclusion

That’s all you need to get started coding with arrays in PHP. You saw how to create arrays and how to retrieve elements from them. You learned the different types of arrays in PHP, and you got a look at some of the most useful built-in PHP functions for working with arrays.