Want to add a touch of visual interest to your WordPress blog posts? Adding odd and even classes can help you achieve a unique and engaging design by styling every other post differently.
We frequently receive questions from our readers about how apply this technique. While many WordPress themes don’t offer a built-in option for odd and even post classes, it’s a relatively simple process to add them yourself.
In this article, we’ll show you how to add odd/even class to your post in WordPress themes.
Why Add Odd/Even Class to Your Posts in WordPress Themes?
Many WordPress themes use an odd or even class for WordPress comments. It helps users visualize where one comment ends and the next one begins.
Similarly, you can use this technique for your WordPress posts. It looks aesthetically pleasing and helps users quickly scan pages with lots of content. It is particularly helpful for the homepage of magazine or news websites.
Having said that, let’s see how to add an odd and even class to your posts in WordPress theme.
Adding Odd/Even Class to Posts in WordPress Theme
WordPress generates default CSS classes and adds them to different items on your website on the fly. These CSS classes help plugin and theme developers add their own styles for different items.
WordPress also comes with a function called post_class
, which is used by theme developers to add classes to post item. See our guide on how to style each WordPress post differently.
The post_class
is also a filter, which means you can hook your own functions to it. This is exactly what we will be doing here.
Simply add this code to your theme’s functions.php file, in a site-specific plugin, or in a code snippets plugin.
function oddeven_post_class ( $classes ) {
global $current_class;
$classes[] = $current_class;
$current_class = ($current_class == 'odd') ? 'even' : 'odd';
return $classes;
}
add_filter ( 'post_class' , 'oddeven_post_class' );
global $current_class;
$current_class = 'odd';
We recommending adding this code using the WPCode plugin. It’s the best code snippets plugin that makes it safe and easy to add custom code in WordPress.
To begin, you need to install and activate the free WPCode plugin. For instructions, see this guide on how to install a WordPress plugin.
Upon activation, go to the Code Snippets » + Add Snippet page from the WordPress dashboard. Then, click the ‘Use Snippet’ button under the ‘Add Your Custom Code (New Snippet)’ option.
From there, add a title for your code snippet, which can be anything to help you remember what the code is for.
Next, paste the code from above into the ‘Code Preview’ box and select ‘PHP Snippet’ as the code type from the dropdown list on the right.
After that, simply switch the toggle from ‘Inactive’ to ‘Active’ and click the ‘Save Snippet’ button.
This function simply adds odd to the first post, then even, and so on.
You can find the odd and even classes in your site’s source code. Simply take mouse to a post title and then right click to select Inspect or Inspect Element.
Now that you have added even and odd classes to your posts. The next step is to style them using CSS. You can add your custom CSS to your child theme’s stylesheet, the theme customizer, or by using the WPCode plugin.
Here is a sample CSS that you can use as a starting point:
.even {
background:#f0f8ff;
}
.odd {
background:#f4f4fb;
}
This is how it looked on our test site:
If you don’t know how to use CSS, then you may want to check out our guide on how to easily add custom CSS to your WordPress site.
We hope this article helped you learn how to add odd/even class to your posts in WordPress themes. You may also want to see our guide on how to style your WordPress comments layout and our expert picks of the best WordPress page builders.
If you liked this article, then please subscribe to our YouTube Channel for WordPress video tutorials. You can also find us on Twitter and Facebook.
Syed Balkhi says
Hey WPBeginner readers,
Did you know you can win exciting prizes by commenting on WPBeginner?
Every month, our top blog commenters will win HUGE rewards, including premium WordPress plugin licenses and cash prizes.
You can get more details about the contest from here.
Start sharing your thoughts below to stand a chance to win!
Sarmad Gardezi says
I want to use it with CPT then how i can use it ?
WPBeginner Support says
It should automatically affect custom post types
Admin
Vera says
Hello,
I was trying to make this work on my test site, where I work with Elementor and Astra. For some reason, once I add the code – everything colors with the “odd” color, and I don’t understand why.
Can you help me sort it out, please?
Vera
WPBeginner Support says
For that question, you would want to check with Elementor to ensure their page builder is not overriding the function and they should be able to assist
Admin
Oliur says
My Blog Name WayTrick. It a Blogger Blog. Now I want to my blog Tansfer to wordpress. How do it?
WPBeginner Support says
Please see our guide on how to switch from Blogger to WordPress.
Admin
kaluan says
This seems not working in Genesis framework? Any additional code needed to add?
onkar says
how to add odd even class in posts for particular page
Bucur says
Ok good function, but css style?
. post {
/ / Rest of the css
}
.odd { } ???
Simon says
Thanks for this. Just what I needed.
Samuel says
How could I take this a step further and target a specific post category?
I have a custom post type – testimonial, and I only want odd/even styling in that section.
Thanks!
Editorial Staff says
You would have to use WordPress conditionals:
http://codex.wordpress.org/Conditional_Tags
Admin
Eric says
This is by far the easiest method of creating odd and even posts for wordpress!! Thanks so much for sharing!
Christine says
As, sadly, css3 selectors are not well supported by all browsers…
I just tried your code for a new twenty eleven child theme i’m customizing, it works so fine,
Thanks a Lot for sharing this ! !
Daniele Zamboni says
What is odd/even class ? Sorry but i’m newbie
wpbeginner says
@Daniele Zamboni These are CSS classes that you can add for styling purposes.