Menu

10 Things You Need to Know About WordPress 3.4

WordPress 3.4 is around the corner. It’s currently beta4 which means a Release Candidate or three will be needed before it drops officially. If you want to test what’s out there now, the way to do that is through SVN. As usual, however, pre-release WordPress is not supported. As usual, however, I have been running trunk throughout the entire development cycle without any problems.

Before I get into the guts of WordPress 3.4, I want to point you to a resource which highlights some of the thinking that is going into the development, now and in the future, of how WordPress is built. Andrew Nacin sent an email to the “hackers” mailing list discussing object-oriented development that informs the thinking of the core developers now that WordPress supports PHP 5.2 and true object-oriented programming.

While it may be over the head of non-developer types, the gist is that now that we (used loosely) can write code smarter, we’re working our way in that direction. Some of the code in WordPress has existed for “generations” of versions and is bulky and inefficient. With new tools at our fingertips, we can begin to approach the idea of refactoring some of this code in better ways. Backwards compatibility is always retained, however, in 99 out of 100 times.WE ARE NOT DRUPAL!

Without further adieu, however, let’s get into what you can expect in the new version of WordPress.

Embed Tweets with oEmbed

Since version 2.9, WordPress has supported a technology called oEmbed that, simply put, has allowed the inclusion of rich media in content in a very simple way. Simply paste a YouTube link on a new line, and WordPress turns it into a properly sized video. No embed code needed. Same for Vimeo, Flickr, Scribd and more. The entire list can be found on the Codex. Now, however, Twitter is supported. Simply place the URL of a tweet on it’s own line and… bam, you have this:

Twitter is an oEmbed provider that is supported out of the box in WordPress 3.4

Query Efficiency Improvements

The common bottleneck for all WordPress users are database queries and data “munging”… that is, what WordPress does with data when it’s returned from the database. The query that brings in all the necessary content necessary to render a page used to look like this:

1

SELECT*FROM wp_posts WHERE...

This has been how the query has worked for years. Really since the beginning of WordPress. And while, in theory that works (and it does, again it has for years), the core reality of this approach is that all the data in the posts table matching the criteria in the WHERE clause is more data than is needed, thus causing potential performance problems.

This approach means the amount of data in memory and floating around WordPress is concise and compact. PHP doesn’t have to work harder to traverse arrays or objects… it is simply a smaller list of data.

But what about the other data? We need the other data! Yes, in fact we do. But since WordPress has an object cache, much of this data is in the object cache. We don’t need to retrieve it from the database.

The second step is to look to the object cache for posts with IDs matching any of the IDs in the first dataset. Anything we can’t find is followed with a second query to get all the information matching the non-matched IDs using MySQL’s IN() function:

1

SELECT*FROM wp_posts WHERE ID IN(10,34,78);

By changing how SQL and object caching is used, WordPress 3.4 finds new efficiencies. In the original ticket, developers were observing 2-3x speed performance improvements. I’ll drink to that.

Theme Customizer

Non-technical WordPress users will love the new Theme Customizer. Otto has a great write-up on this new feature. His video is above. The key takeaway from this new feature is that is possible now to customize a great number of things in a theme from right within WordPress. On the fly. with a live preview.

Change your title, tagline, background color, image and more with a click of a mouse. I can see this being used to create child themes in the future, but for now, it manages settings that are already in WordPress (and accessible in other areas of the WordPress Admin) on the fly. The best way to really appreciate this feature is via Otto’s video above. Related: The best way to leverage this as theme developers is outlined in great detail in his post…

Bundled ‘Touch’ Support

We live in a touchy-feeley world. And by that, I mean mobile. Specifically iOS and Android. In WordPress 3.3, we saw adaptive design come to portions of WordPress. Adaptive design, for the uninitiated, is a technology that elegantly resizes a website to adapt to the the screen it is rendered on. It is a way for developers to create a single experience that works on desktop/laptop browsers as well as mobile interfaces with arbitrary resolutions.

As mobile continues to lead the charge in today’s web, WordPress 3.4 has bundled the jQuery UI Touch Punch library that will give front-end developers more tools to work with in making a website mobile-friendly. Simply include the library via wp_enqueue_script() and now your element has the .draggable() method available. This method enables “drag and drop” support that was previously unavailable and the one major caveat is that it does not support Windows 7/7.5 phones due to limitations in the IE9 browser.

HTML in Captions

Photo by Kyle McCluer and used under Creative Commons. Some Rights Reserved.

I’m trying to rotate between developer tools and user tools in this article, so at this time, I’d like to point out a simple yet important frustration in previous versions of WordPress. When you upload an image and use the media uploader to then insert an image, you have the option of writing a caption. Sadly, it was impossible to include HTML in previous WordPress versions.

Often times, linking the source of a photo is welcome and, possibly depending on the usage restrictions on a photo, required. Before, the only way to do that was to set a link in the media uploader and then the photo would be linked. Now, in WordPress 3.4, you can include basic HTML in your captions as I have done above.

XML-RPC Improvements

XML-RPC. The thing that allows the WordPress apps for Android, BlackBerry and iOS to function. The thing that allows offline editors to function by remotely communicating with WordPress through a public-facing API.

XML-RPC is a venerable technology that is based mainly on the Metaweblog API invented a decade ago. WordPress has supported this iteration of XML-RPC as well as the Movable Type XML-RPC and Blogger XML-RPC APIs for a long, long time. However, WordPress has also extended the Metaweblog API and added it’s own methods along the way.

No more. Instead of band-aiding a solution on top of a limited set of methods intended for blogging only, WordPress 3.4 includes a brand new WordPress XML-RPC API designed to support all the rich features that have evolved since WordPress started focusing on CMS-style features. It incorporates all the methods introduced before as extensions to Metaweblog such as wp.getOptions, wp.getMediaItem, etc and introduces new ones such as wp.getPostTypes and wp.getTaxonomies to name just a few.

It’s important to note that only WordPress products are likely to ship with support for this new API at first, but old capabilities will still exist and function, as backwards compatibility is ensured. As API clients add support for WordPress’ new capabilities, we will see more common usage.

Internationalization (i18n) Improvements

For international WordPress users, WordPress 3.4 continues the tradition of enhancing your experience. As we in the community have stated many times, i18n is incredibly important to WordPress growth and development. In discussing this article with someone inside of the WordPress core community, I am told 2 out of every 3 WordPress users are non-American. Additionally, I am told that 40% of WordPress installations are non-english.

That’s Huge!

The running list of i18n changes in WordPress 3.4 is here. Some notable changes include:

Comma translation. While most languages use a comma as a separater (or delimiter), some do not. This enhancement is useful for languages like Chinese and Arabic that don’t use a comma.

Single-Double quote translation. It’s odd to think, but some languages like Hebrew, actually have distinct meanings for jots that are punctuation marks in an English world.

Default Timezones. It’s possible now to override the timezone WordPress uses in a translation. This, as you can imagine, is important when a language is largely spoken in one region in a single timezone.

Page Template Handling

For theme developers looking to put more organization around their theme file structure, a new change has gone in that has both an obvious, front-facing benefit as well as a background benefit. Now, you can place any page template inside a subdirectory of a theme. So you can now have a /pages/ subdirectory and segregate all of your extraneous one-off or multi-use page templates to that folder (or any folder). WordPress will identify all page templates in the theme root or in a subdirectory of a theme root and make them available for pages to use.

The background benefit of this comes in a new WP_Theme API that is lighter weight, more efficient and handles all the work for you. It’s important to note that most developers will never need to use this API and it is largely considered an “internals” thing.

In relation to the i18n improvements discussed earlier, the headers in these page templates are also now translatable. Simply include a Text Domain: and Domain Path: header in your style.css where the textdomain is the defined textdomain for translations (i.e. twentyeleven) and the Domain Path is the path relative to the stylesheet directory (i.e. the proper place the theme is regardless of if it’s a parent theme or a child theme) where the POT file is (/langs). I don’t want to get too deep into this as Andrew Nacin, the architect of this feature, plans to put out a field guide going into detail. Stay tuned to that.

Custom Header API

For a few versions now, WordPress has supported two functions add_custom_header_image() and add_custom_background(). These two functions have added new menus for designating header and background images to the Appearances menu.

WordPress 3.4 introduces a new API for dealing with custom headers and backgrounds and introduces new flexibility in terms of image sizes, etc. The two functions above have been deprecated (which means they’ll work for awhile but will ultimately go away, so use the new techniques) and replaced with new theme support. If you recall from previous version, we use the add_theme_support() function to, well, add support for a feature in a theme. To integrate the new stuff, include these lines in your theme functions.php:

Both function calls can take a second argument which must be an array of presets, but it’s entirely optional. To omit the second argument renders behavior as we’ve known it for some time. To include it allows theme developers to designate designate parameters for both elements, that can then be customized by the end user.

For custom headers, you may include defaults along these lines (gregariously stolen from the Codex):

Bonus

Did you know?

PHP end of file closing PHP tags are now removed. Those are these – ?> Why is this important? Including the closing tag means that if there is any white space at the end of a file, PHP is likely to break. Omission means that PHP assumes a close tag at the end of the file and whitespace can’t corrupt. Personally I’ve argued for this in the past. The main opponent must have been in a coma when this was slipped through by other core developers.

Distraction Free Writing, first introduced in WordPress 3.2 is now supported by all custom post types.

The theme installer now has infinite scroll which is just kind of pretty aesthetic thing. It also defaults to keyword searches when you’re browsing for a new theme on the WordPress Theme repository.

Post navigation

Bad-ass writeup, Aaron — thanks again for putting together this traditional series.

I’m so freakin’ happy that image captions will now support HTML. It’s been a major thorn in my side, and has produced many headaches with clients who wonder why their posts were looking screwed up after their own attempts to use HTML.

Glad to know about the closing PHP tags as well — that’s a pleasant surprise.

http://websitebuilding.biz/ John

The theme editor looks incredible, and I’m excited by the embedded tweets, but the end of the closing PHP tags is the best news I’ve heard in weeks! There’s not much more frustrating than finding out your xml pages are reading a blank line of output at the top – and spending all day digging through PHP files trying to find the source of that error.

Aaron

I think we’ve all been bitten by this.

http://sucuri.net dre

Well done sir! I was wondering when you would get around to it :)

Aaron

As my second to last “10 Things…” post, I plan a retirement roadshow after 3.5…

http://sucuri.net Dre

Where’s the retirement party?

Aaron

Costa Rica, I’m sure…

http://www.radiumthemes.com frank

Great post. Things can get really messy when theming a plugin like bbpress or buddypress and the new page templates feature is a welcome improvement.
Enough has been said already about the closing php tags :)

http://wpsmith.net Travis Smith

Great summary! Personally, I love WP_Theme as well as the direction WP has taken custom header/background. And Otto’s addition of the Twitter oEmbed is great (and about time, @Otto42’s Tweet)! However, the Twitter API still sucks & people should be encouraged to cache (possibly using site_transient?).

Great read Aaron. Was looking to catch up on where things are at. Thank you!

Michael

A great peek thru the curtains, and although mostly “repurposer” of most things wp, your post was understandable even by me :), so thank you!

Unless I’ve missed something during mp wp journey, or indeed, am completely unaware of a magic plugin, in which version might we expect a way to organize uploaded assets in a fashion other than chronological?

Again, thanks for these peeks!

http://annathewebdesigner.com/ Anna

It’s a bit sad, but the thing I’m most happy about is being able to organize page templates in folders…! =D

http://john.do John Saddington

what a great writeup. didn’t know about some of these things… now is the time for developers to get involved in a serious way with WordPress… it’s only getting better… yikes!

http://prop-14.com Randy

I am happy to hear we can finally put custom page templates into a directory. Do you know if that will also work for file-named templates? (i.e. page-about.php, etc.)

http://www.blumenthaldesigngroup.com Dan

Thanks for a great round up of new changes.

http://jimsmarketingblog.com Jim Connolly

Thanks for the heads-up, Aaron. Some interesting improvements!

http://aardling.com/ Stijn Vogels

Really looking forward to that oEmbed, so I can turn off my Blackbird Pie plugin.

I will also be benchmarking my website performance to see if the query efficiency improvements make any real difference (for me).

Which out of those 10 is your own favourite?

http://nakunakifi.com IAN KENNERLEY

Great write up, there us some really great info here. Personally I am looking forward to the jQuery UI Touch Punch support. I’m gonna download the beta version now! About time the closing tag has been dropped – that’s been bugging me for a long long time. It feels like WordPress is really maturing with the next realease – can’t wait.

http://www.wpsquare.com/ Bharat Chowdary

This is really fantastic stuff and I like many of these features. Thanks for sharing info in WP 3.4

http://eyelashineye.com/ Jacky Moore

Wow I cant wait for WordPress 3.4, my fav feature is the Theme Customizer, I think making it easier to customize your theme might make more people join/switch to wordpress.

Thaks Aaron, Great post.

http://nicethemes.com Juanfra

Great post! Been looking for something like this over the past weeks. All new features look great, the PHP closing tag is a total relief!

Aaron Brazell

My name is Aaron Brazell and I am the author of the WordPress Bible. I work for 10up as a Senior Web Engineer. When I'm not writing code, I am sampling new and different foods, drinking craft beer and practicing my photography. I live in Baltimore with my dog, though I (and he) claims Austin as home.