Layout

4 Basic Criteria for Evaluating a WordPress Theme Framework

Note (last updated: 2024-03-02): The basic concepts in this post are still valid in 2024. But please note that I’ m no longer recommending Headway, WooThemes Canvas or iThemes Builder that are mentionned in this article as valid theme solutions to use in new WordPress projects. All 3 themes have been abandoned for a long time now and would no longer meet my criteria. When I wrote this article, I was already using Genesis which is still an excellent theme for many people. I myself have moved on to other more modern themes in my agency (GeneratePress) for reasons explained elsewhere.

I will soon be writing reviews for some of the main WordPress plugins and theme frameworks that I use in my client projects. But before I do that, I wanted to write a post explaining the basic criteria I use to evaluate a theme because they are not necessarily the same you’ll read about in most other reviews out there that focus on workflow features alone. I’ve read many theme framework reviews in the last 3 years and I found most of them to be lacking in substance. That’s not because they were bad reviews or because the people writing them were doing a bad job, they were just aimed at specific kinds of user that are usually non-coders, beginners or casual users and limited themselves to what I consider “surface” criteria that become far less relevant when you build Web sites with WordPress for a living. When your business and reputation depend on the quality of the themes and other products you install on client sites, “features” like drag and drop and especially “no coding required” quickly take a second or third seat to more important matters like performance, stability, backwards compatibility and flexibility.

So here I’ll explain 4 of the basic criteria I use to evaluate a theme framework’s suitability for inclusion in my workflow to be used on client projects. I’m concentrating on issues I rarely if ever see mentioned in theme reviews so I won’t talk about things like ease of use or any workflow related features here. Those things will be included in my specific theme framework reviews. I hope this article will help you make more informed decisions if you are looking for a theme framework to use on client sites and that you might want to reuse from project to project and are not sure which one would be the best fit for your workflow and your client’s needs.

Who Is This Post For?

This post is mostly aimed at professional or serious WordPress developers, designers and users working as freelancers or in agencies and looking for evolving and reusable solutions. If you can’t code and are not interested in learning because this is not your job or responsibility or you are a hobbyist and nobody’s income depends on the reliability of the WordPress sites you build, then this article is not really written for you. But it might still bring you some valuable information and tips.

But, if you are building or want to be involved in building WordPress sites for paying clients, or if you are not a coder but work in an agency, studio or team where you have a say about the WordPress tools your team is using, then read on. This post is for you.

I make this distinction because, so many WordPress theme framework reviews concentrate only on theme aesthetics or other debatable criteria like the aforementioned and bullshit  “no coding required”. They often fail to qualify the review’s intended audience and forget other important aspects in choosing a suitable theme framework. Many reviewers often use a theme only for a few hours and rarely use it on mission-critical client sites to see how the theme performs over time in the real world before publishing these reviews. When you wait to go through a few WordPress or theme updates, it can reveal very unpleasant surprises if the theme’s developer is not using WordPress standards and best practices or is not careful with changes that can affect the layout of a client site when the theme is updated. In that respect, theme frameworks are definitely NOT created equal! Trust me, I’ve wasted countless hours fixing sites after a theme update broke the layout. To me that is completely unacceptable now and quite avoidable if the developer is careful. But surprisingly, no review I ever read has mentioned this issue! Not one.

Furthermore, a good theme framework takes a significant time investment to master. A seemingly solid framework may have limitations and defects that are not immediately obvious to a new user. They may only be revealed when you need to implement a client requested feature that falls outside the basic theme’s capabilities, or perform a theme update that breaks a site. These are things I experienced personally and they made me waste many non-billable hours. Wasting my time because of someone else’s carelessness is one of the things that irritates me the most.

So, if you too care about your time, know that most of the themes I’ll be reviewing in the future are themes that I’ve used at least once on real world client sites or on my own. If that is not the case, that will be mentioned in the review and you can weight my findings and opinions accordingly.

What Are WordPress Theme Frameworks?

You’ll find plenty of explanations of what theme frameworks are on the Web but I want to quickly define what a theme framework is in my own words so can you better understand where I’m coming from later. Unlike a regular theme, a theme framework is generally a reusable starter point used to integrate your own designs and functionality into a WordPress powered Web site. They are a known baseline you start from to create custom Web sites for your clients. Many theme framework vendors also sell their own pre-designed child themes or skins but, for my purposes here, I’m mostly coming at it from the perspective of someone integrating completely custom designs from a framework’s “default” or base look or a “starter” child theme. This article still applies to themes that are pre-designed but can still be heavily customized through a child theme or other means.

To accomplish this customization work, each theme framework comes with a varying number of user controlled options which can be used to modify the behavior or appearance of the site. Some frameworks have few design options while others have extensive admin sections one can use to change fonts, colors, layout, etc. Some have sophisticated SEO features or come with their own Widgets, shortcodes or even their own Custom Post Types. Some have front end drag & drop UIs used to build page layouts while other have more indirect means to do the same from the WordPress admin or the Customizer. All of this makes it hard to compare frameworks on features alone as they are often not direct apples to apples comparisons.

If you’ve worked with WordPress for some time you are probably already familiar with the parent/child theme concept. I won’t explain that here and you can look it up if you are not familiar with it. Most theme frameworks work using that standard parent/child themes paradigm but others have their own proprietary “skins” system. Not surprisingly, I strongly favor the first kind for several reasons, including the fact that it makes it a lot easier to reuse code if you need to switch themes and believe me … you will! Learning how to personalize a parent theme through a child theme is also a skill that will be much more easily portable to other themes when come time to switch than working with some kind of proprietary “skinning” system.

My 4 Basic Criteria to Evaluate a WordPress Theme Framework

Before I begin I want to clarify one more thing. If you’ve read some of my earlier material here, you may know that I used to work exclusively with one theme framework. That is no longer the case for reasons I’ve explained before. I now own 6 different theme frameworks and I have used 4 of them over extensive periods of time either on client sites or on this site here or on my business site where I’ve used 3 different frameworks in the past. So I’ve lived with these frameworks on real projects for a while. I went through at least one major upgrade with each and several minor ones. I’ve also built very different kinds of sites with them, some simple and some much more complex where I needed to get my hands dirty in the code to get specific results. So I know them well.

Nowadays I try to choose the best theme framework for the project at hand and that choice depends on two main things : one is how complex will the layout be and second, how complex will the functionality be (will I need to use many Custom Post Types, etc.) These have a direct impact on my choice as not all frameworks are as easily customizable as others. So without further ado, here are my criteria.

1- Does the Theme Framework Respect WordPress Standards and Best Practices?

This criteria is one I rarely see mentioned in theme reviews if at all. It’s not on many WordPress users’ radar either because non-coders do not know how to evaluate the technical quality of a theme or framework. That’s why they need help from a review! But this criteria is absolutely key and the people who pay no heed to it are often the ones who are the least able to deal with the issues a poorly coded theme often creates down the line.

What I’m talking about here are things like, does the theme support and use the parent/child theme paradigm. Most modern and popular frameworks do support child themes. To me, that is key as, like I said above, using child themes enables you to modify the parent theme’s default look and behavior without modifying the parent theme. This keeps your customizations safe inside a child theme when the parent theme gets updated. All themes get updated at least once or twice a year or more often so you never want to modify a parent theme directly.

Secondly, does the theme expose WordPress loop code for user modification in standard templates than can be overridden in a child theme? Some frameworks like Genesis do not expose loop code in standard templates directly but offer a sophisticated hooks system instead. I used to be adamant about avoiding themes like that thinking it would be limiting for customization. But as I’ve started to work with Genesis, I realized that using hooks is just a different way of customizing a theme and can work just as well. Sometimes it can even be cleaner as you just need to manage exceptions to a standard loop. Other popular theme frameworks work exactly the same way. My previous go to frameworks, iThemes Builder and WooThemes Canvas do use the WordPress templates hierarchy and these templates contain real loop code you can modify at will. I’m used to that. It makes sense and I used to prefer it but, as I said, I no longer consider this an issue at all as a great framework like Genesis has other means to achieve the same result. I think it actually enables the parent theme to remain more stable. Exceptions are managed in the child theme where they belong with hooks that can override the default loop.

What is far more important to me now is if the theme plays well in the WordPress ecosystem. Builder, WooThemes and Genesis certainly do that. Headway, not so much and Thesis even less so. For me, that is a real problem. When you need a “connector” plugin to support other sometimes very popular plugins and make them work in your theme when that same plugin works out of the box in most other themes, this complexifies things needlessly and this is one of the reasons I started using themes like GeneratePress instead of Genesis in late 2018 early 2019.

When you start using WordPress as a CMS and get requests from clients for custom functionality, you’ll need to rely on complex plugins and advanced WordPress features like Custom Post Types to be able to deliver them to your clients. If your framework or parent theme respects WordPress standards, that will be a lot easier than if it doesn’t. Again, this criteria is rarely if even brought up in theme reviews when it should be front and center IMO as it is very hard to gauge when you have not used the theme or are not very technical.

Lastly, another issue related to WordPress standards is that a theme should generally limited to controlling the look of a site as much as possible leaving behavior and content control to plugins. For example, many themes and theme frameworks add portfolio functionality to Web sites. Most do it through Custom Post Types. If that content should survive a theme change (as portfolio data usually does), it should be implemented through a plugin and not the theme. Many themes still “break” this rule and even use that fact to sell their theme and add to its list of features… and many less technical users fall into that trap. That is one of the reasons I always recommend avoiding getting a theme from theme “market” type web sites like Themeforest as these lenghty features list are often how theme vendors on these markets try to stand out at the detriment of speed, ease of use and ease of updating. Avoiding this type of “everything and the kitchen sink” type of themes will make your life much easier now and down the line as they often carry a heavy technical debt.

2- Does the Theme Framework Support Industry Standards and Best Practices?

In other words, is the Theme’s HTML and CSS  code well organized and easy to read and modify and is the HTML valid and as clean and semantic as possible?

Here I’m talking about front-end code quality. Is the HTML, CSS and JavaScript code that the theme framework outputs valid and error-free. Is the theme framework responsive? Is it somewhat accessible. Accessibility is not such a popular topic anymore but it will always be important. In some industries, it will be required by law to follow base accessibility requirements. Is the code as semantic as can be? That has a direct impact on SEO. Here, theme frameworks that support HTML 5 like Genesis, Headway and WooThemes have an edge. With version 2.0, Genesis even added Schema.org markup that is very good for SEO

Fortunately, this criteria is easier to judge than the first from the theme vendor’s demos where you can look at the theme’s HTML and CSS code directly. You can check for code validity, see if the code is clear and readable, etc. Themes vendors cannot hide their product’s weaknesses here. If the theme’s front-end code is sloppy, it might be a good indication that the PHP code in the back-end code is the same.

Theme demos can also give you an idea of the theme’s speed but they are often hosted on powerful dedicated servers that do not reflect a more typical shared hosting environment if that’s what you are using. You can still compare themes with one another and get some idea of their respective speed. Unlike other things, many of the most popular theme framework and multipurpose parent themes have been compared and bench marked for speed and performance before. A quick Google search should yield those comparisons easily. But again, make sure the source is reliable and not biased to a specific theme because they are paid to be.

For people like me that often use a framework’s basic starter child theme to integrate a custom design this criteria is essential. Theme frameworks’ basic starter child themes are often quite plain which is normal. When building a child theme and adding my own styles, I don’t want to fight the theme’s built-in styles every step of the way. So their CSS needs to be well written and the selectors can’t be too specific. Overuse of !important will also make your customization work harder. Inline CSS styles should also be avoided as much as possible. You can easily replace a theme’s style.css completely in a child theme but most frameworks have other “fondational” or layout stylesheets they rely on. These styles should also be easy to override if you have to alter the layout significantly.

Regarding HTML, a framework often has to balance flexibility with clean and semantic HTML code. Here, modern themes like Genesis, GeneratePress and Astra have very well optimized HTML code and let you style any of their elements in a specific and detailed manner while keeping their HTML code light and semantic.

3- Is The Theme Stable Through Minor Updates and Major Upgrades

This one is HUGE for me. WordPress is by far the most popular CMS out there. With that popularity comes the reality that it is a target for hackers. So all components of a WordPress site, be it plugins, themes or WordPress itself need to be updated frequently to remain secure. In the more than 10 years I’ve been working with WordPress, few updates have caused me issues like layout changes or broken functionality but, the issues I have encountered were, by far, most often caused by theme updates, not by WordPress or plugins. This criteria is impossible to judge and review after using a theme only a few hours or a few days. That’s why theme reviews never mention it that I have seen but, to me, this criteria is a deal breaker.

Minor Updates

Here I’m talking about a parent theme updating from version 5.2.3 to 5.2.4 for example. Or from 5.2 to 5.3. These are usually bug fix updates although theme vendors often add new functionality in minor updates too. Ideally, minor parent theme updates should never bring changes that can break a site’s layout or functionality. Few themes have a perfect record here but, up until now in 2020, Genesis, GeneratePress and AstraPress have been very stable for me (Genesis being the theme we’ve used the longest and are still using and Astra being the most recent). We’ve gone through major upgrades of these 3 themes without any site layouts or functionality breaks.

I can’t say the same for WooThemes Canvas that released an update at some point that modified its HTML markup enough and without any backwrads compatibility options that my custom CSS stopped working and had to be rewritten. By far, the worst in that respect for me has been Headway 3.x. Early updates had markup changes that were very important like removing IDs in footer markup and replacing them with classes which had the effect of completely breaking the custom CSS that was relying on those elements’ IDs. That was with a minor second decimal update (3.0.4 to 3.0.5 if I remember correctly). Thankfully, I had only one site on Headway 3.x at that time. For me, changes like that are unacceptable. It revealed very poor planning on the developer’s part as these kinds of decisions should have been made long before releasing Headway 3 and the markup should not have changed this significantly after that.

Which brings us to major upgrades.

Major Upgrades

Here I’m talking about upgrading major versions like from version 1.x to version 2.0 for example. That is a major number change that usually brings major new functionality and change. Theme vendors have two very different philosophies when it comes to major upgrades and the validity of each philosophy is much less clear cut than in the case of minor updates. In the latter, stability should be a given IMO. I can’t be expected to have to fix my custom code every time a theme releases a minor second decimal or security update.

But in the case of major upgrades, theme vendors sometimes treat that as an opportunity to do total rewrites that break with the past completely. Headway did that when they released version 3.0 and Thesis did the same when they released Thesis 2.0. Both broke completely with the past and sites running the previous versions could not be updated to the new versions without major rework. It’s basically like switching to a new theme from a different vendor.

I had stopped using Thesis long before that upgrade happened but I lived through the 2.0 to 3.0 Headway upgrade and it was painful for me as a lone freelancer at the time as I had many client sites on Headway 2.x with active maintenance plans. Headway had long promised some kind of upgrade path from Headway 2 to 3 but they never delivered on that promise. I could not justify billing the time I’d require to update those sites to my clients as the sites visual design would not have changed and my clients requested no changes to their sites. So I took on me to migrate those sites to other more stable themes… lesson learned!

In the case of iThemes Builder, Genesis and GeneratePress, I’ve lived through 1 or 2 major upgrades. In all 3 cases, no sites have been broken and no rework was required. These upgrades brought major features like making the site responsive (iThemes Builder) or changing the HTML markup from XHTML to HTML5 (Genesis). in Both cases, adding a line of PHP code to the child theme’s functions.php file was required to bring in the new feature. If I chose not to add it, the theme kept working as before with the new version’s other benefits like improved security. That’s what’s called backwards compatibility and, in my view, it’s the responsible way to upgrade a theme with a large existing install base.

So here you have a decision to make when you choose a theme framework. You will need to look into the vendor’s history and see how they treat major upgrades and how those have affected their existing customers. In the case of iThemes (Builder), StudioPress (Genesis) and GeneratePress, you get theme vendors that offer backwards compatible major upgrades that do not break existing sites. In the case of Thesis, Headway and others, you might get complete breaks from the past. Some would argue that the changes in both were substantial enough that the break and major rework required to upgrade existing sites was justified. To me, they were not, but only you can decide that for yourself.

Another thing to consider is that, when a theme releases a major upgrade, it may be time to review the site’s design anyway so that upgrade’s stability or lack thereof may not be a bid deal to you. At that point, you may decide to change the site’s look completely anyway. The only thing is that you need to be aware of it BEFORE you choose a theme framework as future upgrades may be either painless or a major hassle if you want to stay with the same vendor. Nothing will give you a definitive indication of how smooth or difficult a specific framework upgrade may be, but you can easily ask around on social media or read a theme vendors forum to try and find out in advance how these things were handled in the past.

In my case with Headway, I feel like they have let me and their other pre 3.0 users down. They’d say it’s the cost of innovation and many agree with them. I don’t, so I made my own choices and they lost me as a customer and evangelist. But I still had to pay the price of living with a mostly unsupported product that was left without updates with a known and serious security vulnerability for over a year. There was an old and insecure TimThumb version in Headway 2.0.13 that was the current version when Headway 3.0 was released and this was updated only when 2.0.14 was released over a year later.  To me that is downright reckless and irresponsible. So Headway has failed to meet the responsible upgrade criteria for me in every way and I’ve added this as an example here for illustration purposes as Headway and the company behind it are de facto dead now.

4- How Solid and Reliable is the Theme Framework’s Vendor

Regardless of the technical aspects of theme selection described in the 3 previous points, a theme vendor’s reliability may be the most important criteria. Here I’m talking about the ability of the vendor to support and improve their product adequately over time. In my experience, larger companies like iThemes (Builder), StudioPress (Genesis) and WooThemes have provided me much better support and a better overall customer experience that smaller 2-3 persons companies like Thesis and Headway (Thesis may have more people now). Companies with larger staffs can generally handle more customer support requests and can invest more resources in the planning and development of their products.

This should weigh in your choice too but don’t judge a product solely on this criteria. Smaller outfits like CobaltApps (makers of the former Catalyst theme and the Dynamik WebSite Builder and Extender plugin for Genesis) are doing incredible work on very focused products and they support and document them very well. Same with the GeneratePress theme which is basically one developer with a small support staff yet is one of the best supported WordPress products I have ever used. It’s just one more thing to take into consideration.

Conclusion

As you may have guessed, my first selection criteria is quite hard to judge if you do not already own a specific theme framework and cannot try it in a local or development test environment first. So are the quality of the vendor’s support and their ongoing product improvement. Most theme vendor’s pricing is quite reasonable IMO and, as these products will likely enable you to serve several clients, you could make an investment in more than one of them as I did and test them thoroughly before you decide on one for a specific project. That is what I’d advise you to do. Points 3 and 4 will require some research on your part but that time investment will pay off in the future as well. It may help you get passed a positive first impression of a product based on an impressive list of features or marketing copy and push you to look deeper at these not so obvious things that can have a huge impact on your experience with a theme framework.

I hope this article has been helpful to you. You can look forward to specific theme framework reviews in the future but you will now know the 4 basic criteria I look at before I even dive that deeply into features and workflow. I hope this helps you make more informed choices!

This post is also available in Français.

4 thoughts on “4 Basic Criteria for Evaluating a WordPress Theme Framework”

    • Glad you like it Chris thank you! These criteria are there because I learned the hard way how important they are. Since I wrote this, my respect for Genesis and StudioPress has grown quite a bit. Same for the community surrounding it which is an aspect I have not really mentioned here but is also very important, especially when you start to work with a framework. It could have been my 5th criteria here.

      Going through a busy phase here which enables me to work with Genesis on client projects so I can write about it with a modicum of intelligence later 😉

      Reply
  1. Hi Stephane,
    I have existing content (equivalent to 100 posts). How easy is it to migrate from one paid theme/framework to another? Do vendors let you test run for a week and then decide? If so, would it be a good idea to load up my content in plain vanilla WP postings and then see how it looks under different themes? thanks for an interesting article.
    -mj

    Reply
    • Hello MJ,

      Generally, basic content (pages, posts, media items) will not be affected by a theme change other than style changes (fonts, colors and layout may be different). The content itself will be intact in the database and doesn’t need to be “migrated”.

      The exception is if your previous theme added shortcodes and you used them in your content or if the theme added its own Custom Post Types for things like portfolios, testimonials and the like which are very unlikely to be supported by the new theme. The data for this content will still be in the database (a theme change won’t erase any type of content), but it probably won’t be displayed in the front end when the new theme is activated.

      That is why Custom Post Types, shortcodes and anything closely tied to the content should always be handled by plugins, not themes. And that’s why the trend of “kitchen sink” themes like many at Theme Forest and other sub standard theme shops is so bad for the WordPress users community. Stay away from this type of themes. This is certainly one of the reasons I’ve always stuck with simpler frameworks like Builder and now Genesis.

      Whatever you do, you should always test any major changes to your site on a development copy of the site on your live server (usually using a sub-domain) or a local development environment (I’m on Windows so I use WAMP Server).

      If you want to check if any content “disappears” from your site after a theme change and you are not yet decided on a new theme, switch to TwentyTwelve on a test copy of the site and check each page. It is possible to get custom content back that was created through an old theme’s features but it will be a matter of digging into the old theme code and get the details of how the Custom Post Types were created (if that’s what was used) to recreate them with a plugin like WP-Types or Easy Content Types. Same with shortcodes. A good dev would be able to do this but it could take a few hours.

      HTH!

      Thanks for your comment!

      Reply

Leave a comment