Jump to the navigation menu

Why use Collections?

Yesterday, I wrote how to create dependency free Collection classes in PHP (thanks to Dan Leech).

I said that I've written blog posts and given talks on using Collection classes.

But why do I like Collections and why may you want to use them instead of native arrays?

The first reason is that I can add extra functionality to Collections, because they're objects.

Whether it's a generic action such as filtering or sorting the items, or something more specific like returning a list of station codes from a collection of train stations, this can be added to specific collection classes.

I'll usually have an AbstractCollection that has the generic methods and is extended by specific Collection types with methods more specific methods.

Having specific types of Collection objects also gives my code more context.

Instead of an array that could contain anything, by reading the code and seeing which Collection types are used, I know what the collection contains and what I can do with it.

This is also why I like value objects.

Giving objects specific names instead of relying on the language's primitive types makes the code more robust and easier to read and understand.

- Oliver

Was this interesting?

Sign up here and get more like this delivered straight to your inbox every day.

About me

Picture of Oliver

I'm an certified Drupal Triple Expert with 18 years of experience, a Drupal core contributor, public speaker, live streamer, and host of the Beyond Blocks podcast.