Trusted WordPress tutorials, when you need them most.
Beginner’s Guide to WordPress
WPB Cup
25 Million+
Websites using our plugins
16+
Years of WordPress experience
3000+
WordPress tutorials
by experts

How to Add Odd/Even Class to Your Post in WordPress Themes

Want to add a touch of visual interest to your WordPress blog posts? Adding odd and even classes can make your layout more engaging, breaking up long lists of posts with subtle design changes that catch the eye.

We frequently receive questions from our readers about how to apply this technique. While many WordPress themes don’t offer a built-in option for odd and even post classes, we found a quick and easy way to add them yourself using the free WPCode plugin.

In this article, we’ll show you how to add odd/even class to your post in WordPress themes.

Adding Odd/Even class to your posts 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 the 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 like WPCode.

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 recommend using the WPCode plugin to add this code. It’s the safest and easiest way to manage custom code on your site without having to edit your theme’s functions.php file directly.

We use WPCode to handle all the custom snippets across our portfolio of websites. It keeps everything organized and prevents code from being erased during theme updates.

To learn more about this code snippets plugin, see our complete WPCode review.

WPCode

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 ‘+ Add Custom Snippet’ button under the ‘Add Your Custom Code (New Snippet)’ option.

Adding Custom Code in WPCode

Next, you need to select a code type from the list of options that appear on the screen.

For this tutorial, choose ‘PHP Snippet’ as the code type.

Select PHP Snippet as the code type

You’ll now be directed to the Create Custom Snippet page.

From here, add a title for your code snippet, which can be anything to help you remember what the code is for.

After that, paste the code from above into the ‘Code Preview’ box.

Paste the code to add odd/even class to your posts

Once that’s done, simply switch the toggle from ‘Inactive’ to ‘Active’ and click the ‘Save Snippet’ button.

Activate and save your custom code snippet

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 the mouse to a post title and then right click to select Inspect or Inspect Element.

Odd and Even classes in source code

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:

Posts using alternate background colors with even/odd css classes in WordPress

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.

Additional Resources for Customizing WordPress Pages and Posts

We hope this article helped you learn how to add odd/even class to your posts in WordPress themes. You may also want to check out these other articles to further customize your site’s design:

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.

Disclosure: Our content is reader-supported. This means if you click on some of our links, then we may earn a commission. See how WPBeginner is funded, why it matters, and how you can support us. Here's our editorial process.

The Ultimate WordPress Toolkit

Get FREE access to our toolkit - a collection of WordPress related products and resources that every professional should have!

Reader Interactions

16 CommentsLeave a Reply

  1. 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

    • 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

  2. 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!

  3. This is by far the easiest method of creating odd and even posts for wordpress!! Thanks so much for sharing!

  4. 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 ! !

Leave A Reply

Thanks for choosing to leave a comment. Please keep in mind that all comments are moderated according to our comment policy, and your email address will NOT be published. Please Do NOT use keywords in the name field. Let's have a personal and meaningful conversation.