WordPress Frameworks Compared on Performance

Themes & Plugins

The Goal

There are some great posts out there that compare WordPress frameworks. My recent favorites have been by Clifford Paulick. His part A and part B are the hallmark of robust comparisons. In a conversation with him a few months ago, I wondered aloud about a comparison of their performance. I've seen WordPress Frameworks compared by tons of factors including features and price like Clifford did, but I've never seen them looked at from a performance perspective.

And you can see why. You'd first have to buy them all, which most folks wouldn't do. Then you have to design a single layout that all could do – which means you'd have to know how they all work. And then you'd run your performance tests.

But if you did such a thing, you could let people know that – all things being equal – which theme frameworks performed better than others. And that might, just maybe, be interesting to someone who was looking to purchase just one and get to know it well.

The Competition

Before I get into methodology, let me give you some context on which theme frameworks were compared.

  1. Numer of theme frameworks: 7
  2. All personally purchased – no freebies to influence my testing.
  3. One xml export from ChrisLema.com – 157 posts, 583 comments, 33 pages, 6 categories.
  4. One standard blog layout with a custom menu, and three elements in the sidebar (About me, Twitter feed, Tag list)
  5. 10 posts on home page
The theme frameworks compared were:

Comparison Methodology

What I did was jump over to my playground (wpadvisor.com) where I do all my testing and I created seven sites on that multisite site. So each site was stand alone. And in each site, I imported the same file. I even imported images so they'd be local. After the import, I deleted the initial post and page, and configured the menu to show the core set of categories. From there I configured the sidebar to have the widgets that I mentioned above. Each theme had different requirements to get all that configured, but none of them took longer then 20-30 minutes to get everything done.

Then I hit each site multiple times. Because I wanted to make sure none of these sites would do their first load during the test.

At this point I should mention that no caching plugins were installed because I host my playground on WP Engine where things move fast without them. I should also note that the page speeds here may not match your own experiences if you're hosting your site on crap solutions by companies rhyming with MoBaddy.

At that point, I took the home page urls and feed them to the Tools page at Pingdom.

I captured the data and pulled it into spreadsheets for comparison. So here's the info you've been waiting for.

Comparing Request Counts

[table id=2]
Framework,# of Requests
Headway,12
iThemes Builder,15
Genesis,19
Pagelines,21
Catalyst / Dynamik,22
WooThemes (Canvas),25
Ultimatum,28
[/table]

As you can see, the spread was wide. I would have guessed that it was much tighter together, but that wasn't the case. That said, it only matters in my mind if there's a relationship between the count and the load time. Which is why you'll see how some of the larger request counts still did well in terms of speed to load.

Comparing Load Times

[table id=3]
Framework,Load Time
Headway,226 ms
Genesis,964 ms
WooThemes (Canvas),992 ms
Catalyst (w/Dynamik),1.2 s
Ultimatum,1.22 s
iThemes (Builder),1.26 s
Pagelines,5.18 s
[/table]

Headway blew the others away – which may have been helped by how few requests it made. But WooThemes loaded up quickly despite it's request count. Falling to the bottom was Pagelines, but that wasn't surprising when you see the next table (looking at page sizes).

Comparing Page Sizes

[table id=4]
Framework,Page Size
iThemes (Builder),299 kb
Headway,1.1 mb
Genesis,1.1 mb
Catalyst (w/Dynamik),1.6 mb
WooThemes (Canvas),1.7 mb
Ultimatum,1.8 mb
Pagelines,5.2 mb
[/table]

iThemes and Headway jumped in front, but many of the others were right behind them. Except Pagelines, which was a bummer.

Looking at Pingdom's Performance Grade

[table id=5]
Framework,Pingdom Perf Grade
iThemes (Builder),100
Headway,98
Pagelines,96
WooThemes (Canvas),94
Ultimatum,91
Catalyst (w/Dynamik),90
Genesis,84
[/table]

Any time you get a combined score from anyone, like Pingdom, it's worth digging into how they're creating their algorithm. I confess, I didn't do the digging. I may later. But that's mostly because all of the themes had a nice high score. I've seen sites that have far lower than 84 in the total Performance grade.

One other thing to note is that many of the factors that affected the performance grade could have been solved by minifying static files, combining them, and using a CDN. But I wanted a straight comparison, so I left things native.

Conclusion

As always, your selection of a “winner” is based on what you value most. Not every theme here was a drag and drop framework – and maybe you care about that more than anything. Some are easier to learn than others.

In terms of pure performance, Headway seemed to run away with things with iThemes in second place. Genesis & WooThemes were right behind, when I created an amalgamated score.

What does that tell us? Well one interpretation would go like this:

The players that have been in the game longest have had the time to really optimize their frameworks for performance.

You might have a different take. That's on you.