Your friends at Viget present Inspire, a Design & Interaction Blog

Switching Mindsets: From WordPress to ExpressionEngine

I've been a devoted WordPress user for the past four years. I had invested quite a bit of time into learning MovableType when a developer friend suggested I try WordPress instead. The minute I saw its templating system, which is both flexible and easy for a designer like me to grasp, I was sold. It proved to be remarkably "hackable" and at Syracuse University (my previous employer), we frequently used it as a web content management system for clients with simple needs. It worked well enough, and I was content to stick with a single software package -- until now.

Before coming to Viget, I never had the opportunity to build a site using ExpressionEngine. At colleges and universities, it's common to use open-source software, partly because of budget constraints but also because the idea of collaboration and knowledge sharing is so synonymous with academia. So when I was tasked with implementing a client site in EE, the geeky side of me was thrilled while my designer side was nervously wondering if it would require more programmer smarts then I have.

After a quick overview, I dove right in, Googling anything that didn't make sense. There is plenty of good documentation and a great support forum, so finding answers to my questions was easy. I have good news for all you designers out there: no crazy, black-belt coding skills required. It only took a few days to learn the basics and get my first EE site up and running flawlessly. There were a few things I struggled with, though -- for example, mental roadblocks that probably wouldn't have been as confusing had I not been entrenched in the WordPress ways of doing things -- so for other WordPress users thinking of switching, here are a few tips:

  1. Get over the term "weblog."  To me, a weblog meant a big -- well -- blog, with all sorts of page types and info and categories and whatnot attached to it. In EE, a weblog is a container used to store information and organize your data. I used a separate weblog for nearly every page in the small site, which seemed counterintuitive at first. It makes more sense when you start creating custom fields and assigning them to each weblog. Basic lesson: Don't be afraid to make lots of weblogs for a single site. You can change your preferences to call it something else (like "section"), but the template tags will still call them weblogs, so I found it easier to just adjust my thinking. (Note: Rumor has it this term is being dropped in the upgrade to 2.0, so in a few months you won't have to worry about this!)
  2. Start thinking in smaller chunks. In ExpressionEngine, it's much easier to break your pages up into structured pieces of content (title, thumbnail image, summary, body content, etc) using custom fields. You can create custom fields in WordPress, but it ain't easy and it often feels like you're doing backflips to cobble together complex pages. In EE, you can make as many custom fields (bundled into "field groups") as you want. You then assign the field group to a weblog, and voila! Lovely structured data. The level of control you have is amazing, and it doesn't require extra downloads or add-ons. Which leads me to #3...
  3. Say goodbye to crappy plugins. If you want to do anything fancy with WordPress, it requires a plugin. Which is no big deal; downloading and installing one takes all of a minute or two. BUT, you have to sort through a lot of garbage to find a plugin that works and is not in perpetual "beta." Because WordPress is open source, programmers everywhere are writing their own plugins for it. Some of them are awesome. Lots of them aren't. EE has much more out-of-the-box functionality. The only plugin I installed was for a mail form, and it worked great without any tinkering. The add-ons in the ExpressionEngine library have been tested and accepted by its creators, so you can expect them to work.
  4. Finalize your design before moving it into the system. My original xHTML/CSS templates and the templates I ended up with in WordPress usually weren't all that different, so modifying them outside of the editor and then copying/pasting them in wasn't a big deal. In EE, my original templates got chopped up into small chunks right off the bat. This made big design changes overly confusing. Next time around I'll spend more time working out design details before I move the display templates into EE.
  5. Expect to spend a while finding things in the control panel. It seems unnecessarily convoluted. It took me a while to find things and memorize the patterns. Create a weblog, then create a field group with custom fields, then assign that field group to a weblog, then make a post in the weblog.... yikes. It felt like a lot of steps. I know it's partially because you have such fine grain control over things, but I'm sure the interface could be simplified so everything wasn't five clicks away. Saving graces: you can use the back button, and you can open multiple tabs to work on things. I often keep my stylesheet template in one tab and another template (like a page template) in a separate tab so I don't have to navigate back and forth quite so much. It appears the upcoming ExpressionEngine 2.0 upgrade will be a huge improvement, so I can muddle through until then.
  6. Say goodbye to PHP tag soup. My EE templates look so pretty and streamlined compared to my WordPress templates!  With so many built-in functions, there's just a lot less code to look at. All I have to say is, HOORAY. I'm obsessive compulsive by nature, so a few lines of clean code makes me much less anxious.

Shifting my thinking (and learning a CMS new system) was well worth the effort. I have found EE to be much more powerful than WordPress, and not nearly as hacky. I'm looking forward to working with it more in the future. There seems to be no end to its functionality, so it'll keep me busy for a while.

A few sites I found especially helpful:


Get More From Viget

Subscribe to get our monthly newsletter and occasional special announcements.