Using Divi Template Hooks with Conditional Logic

In my previous post I showed you how to display any layout saved in a Divi library as a global footer just by adding a function in the functions.php file. Let’s take this method one step further. In this tutorial, I’ll show you how to display different layouts on different pages using WordPress Conditional Tags. We’ll be able to create nice blog categories header section.

Divi Theme Builder

Elegant Themes have already announced they’re working on the “Theme Builder”, which will allow us to use the Divi Builder to design every pixel of our website. As soon as it’s available you won’t be needing this technique, but until then…


WordPress Conditional Tags

Conditional Tags are an awesome WordPress feature, which we can use to display different content on a given page, depending on the conditions that this page matches. A Conditional Tag simply checks if certain condition is met and returns either true or false. They usually work with PHP if /else Conditional Statements. You can find a list of all available tags in the WordPress Codex, and we’ll have a closer look at some of them in this tutorial.

Basic example:

if ( is_front_page() ) {
// do something

Useful Conditional Tags examples:

  • is_home() – returns true if the main blog page is being displayed. If you choose to display a static page in Settings -> Reading, this tag will return true for the “Posts page”.
  • is_front_page() – returns true if the front of the website is displayed, it can be either a posts page or a static page.
  • is_single() – returns true for any type of single post.
  • is_page() – returns true if any Page (post type page) is being displayed.
  • is_page(99) – returns true if a page with the ID 99 is being displayed.
  • is_page(‘sample-page’) – returns true if a page with the slug “sample-page” is being displayed.
  • is_page(‘Sample Page’) – returns true if a page with the title “Sample Page” is being displayed.
  • is_category() – returns true if a category archive page is being displayed.
  • is_category(99) – returns true if a category with the ID 99 archive page is being displayed.
  • is_category(‘sample-category’) – returns true if a category with the slug “sample-category” archive page is being displayed.
  • is_category(‘Sample Category’) – returns true if a category called “Sample Category” archive page is being displayed.
  • is_tag() – returns true if a tag archive page is being displayed.
  • is_author() – returns true if an author archive page is being displayed.
  • is_search() – returns true when a search result page archive is being displayed

Sometimes we may need to do something on every page but one, or on every category except for one. The ! will help (exclamation mark is a PHP logical operator for “Not”). Take a look at this code:

if ( !is_page(99) ) {
// do something everywhere except for the page with the ID 99


Editing Divi Blog Category Pages

If you have a Divi blog with multiple categories, you might want to display different headers for each category. Normally, we can’t edit that part of the page, but we can use et_before_main_content Divi template hook to display our layout right between the top navigation and blog posts list.

All that matters is that your layout is saved in the Divi Library.

Free Resources for Divi Lovers

Join our newsletter to get the good stuff!

We’ll provide you with updates on new tutorials, webdesign assets and special offers. Get top quality Divi goodies straight into your inbox! Read our Privacy Policy to learn how we manage and protect your submitted information.

Sign up to download

Get access to this layout and all the free resources made exclusively for our subscribers!

Already subscribed?

Fill the signup form and if you’re on the list it’ll get you straight to the download page!

Can’t see the form? Click here

Setting Up the Layouts

We need to create separate header designs and save each one as a separate layout in the Divi Library. My example uses additional layout for the main blog page, which is the page you’d choose as “Posts Page” in your WordPress dashboard under Settings -> Reading. I have 5 categories on my sample blog and 6 layouts to be used saved in the Divi Library.

Display Divi Layouts with a Template Hook

Divi comes with a few template Hooks (Filter and Actions), which allow us to add custom code to different parts of the site without editing template files. You might want to read this guide by SJ James from Divi.Space explaining how the hooks work. You can check all the available template hooks in the Divi Documentation page.

In this example we’ll use the et_before_main_content action hook, which is triggered after the header, before the main content is output. That is the perfect moment to place some custom aheader design.

Add function to functions.php

We need to add a function to our child theme’s functions.php file. This is the code I used:

function dl_blog_headers() {
	if ( is_category('travel')) {
		echo do_shortcode('[et_pb_section global_module="13318"][/et_pb_section]');
	elseif ( is_category('beauty')) {
		echo do_shortcode('[et_pb_section global_module="13355"][/et_pb_section]');
	elseif ( is_category('health')) {
		echo do_shortcode('[et_pb_section global_module="13358"][/et_pb_section]');
	elseif ( is_category('food')) {
		echo do_shortcode('[et_pb_section global_module="13359"][/et_pb_section]');
	elseif ( is_category('fashion')) {
		echo do_shortcode('[et_pb_section global_module="13356"][/et_pb_section]');
	elseif ( is_home()) {
		echo do_shortcode('[et_pb_section global_module="13359"][/et_pb_section]');
add_action('et_before_main_content', 'dl_blog_headers');

That’s it!

What this function does is simply display different layouts on different category pages. Make sure you replace your layout IDs and category slugs (you can use slugs, category name, or category ID).
You can check the layout, category or page ID in the address bar of the browser when you’re editing that element (it is in this part of the URL: …/wp-admin/post.php?post=999… ).

If you’re our subscriber feel free to download the categories header layouts I use on my sample demo page.

Any other ideas?

Please share any other modifications to your Divi-based websites you were able to make using this method. I’d love to hear all about different ways you’re using Divi Hooks and conditional logic. And if you have any questions or would like me to create more similar tutorials with different use cases – let me know in the comments!


Have you seen our

Divi child themes?

Divi Toolbox plugin?

We offer a great selection of high-quality Divi products to speed up your work. Feel free to use a coupon code IREADBLOG at the checkout to get a 10% discount!


  1. Marco

    I would like to present the visitor with 3 choices. Depending on his/her choice 1 Divi Section should become visible. The other 2 INvisible.
    Example: Do you want 1) New website 2) Redesign Website 3) Woocommerce shop.
    Section 1 would be text etc. for customer who wants a new website
    Section 2 text and images for customers who have a website but want it redesigned.
    Would this be possible ?

  2. Niki Maria

    I am exploring how to use this to create category and subcategories and I got it working, THANK YOU! Now I want to try to get the code to not reload the whole page. Anyone have any ideas?

    • Ania Romańska

      No, sorry, it won’t be possible using this method, as these are separate URLs.

  3. Amy S Chaplin

    Hi, I’m trying to add a custom footer on every page/post unless the blank page template is applied (page-template-blank.php). Can you tell me what I’m doing wrong? I’m currently seeing it on all pages.

    if (!is_page_template(page-template-blank.php)) {
    // do something everywhere except for the pages that are set to blank template
    function mp_add_custom_footer() {
    echo do_shortcode(‘[et_pb_section global_module="842"][/et_pb_section]‘);
    add_action( ‘et_after_main_content’, ‘mp_add_custom_footer’ );

  4. Samar Jamil

    How can i do this same on the author Archive page.

  5. xmg

    Also, if you are looking for conditional tag for single project pages, the condition is:

    if ( is_singular(‘project’) )

    If you only use the conditional tag is_single, this will apply for both blog posts and project pages.

    If you need both, you can do elseif such as:

    function custom_footer() {
    if ( is_singular(‘project’) ) {
    echo do_shortcode(‘[et_pb_section global_module="1825"][/et_pb_section][et_pb_section global_module="621"][/et_pb_section][et_pb_section global_module="19"][/et_pb_section]‘);
    elseif ( is_single() ) {
    echo do_shortcode(‘[et_pb_section global_module="141"][/et_pb_section]‘);
    elseif ( is_page() ) {
    echo do_shortcode(‘[et_pb_section global_module="19"][/et_pb_section]‘);
    add_action(‘et_after_main_content’, ‘custom_footer’);

    You can combine multiple Divi library layouts by adding more such as:

    echo do_shortcode(‘[et_pb_section global_module="1825"][/et_pb_section][et_pb_section global_module="621"][/et_pb_section][et_pb_section global_module="19"][/et_pb_section]‘)

    Hope this helps

  6. Andrés

    Hi Ania.
    Great post and congratulation for your job!.

    I have some doubts:
    1. Can I use this with project_category? and
    2. Can I to show the project category page as grid?

    Thank you so much!!
    Greetings from the cold Valencia 🙂 🙂

    • xmg

      Here’s a modified version that works for Project Categories. Note the ‘for-lease’ is the category name and replace spaces with hyphens. Repeat elseif in the same way with the last one using just ‘project_category’ for everything else.

      function project_cat_headers() {
      if ( is_tax( ‘project_category’, ‘for-lease’) ) {
      echo do_shortcode(‘[et_pb_section global_module="19"][/et_pb_section]‘);
      elseif ( is_tax( ‘project_category’) ) {
      echo do_shortcode(‘[et_pb_section global_module="621"][/et_pb_section]‘);
      add_action(‘et_before_main_content’, ‘project_cat_headers’);

  7. shahala

    Hello Ania!

    I want to display my section in some single posts with specific categories only (I mean to say not in all posts) How can I do so?


  8. Gegli

    It was very useful
    thanks …

  9. Walter Corredor

    Anya! You saved my day. Thanks a lot!

    • Walter Corredor

      Anya, i guess that you’re busy. I’ve tested in localhost but in the live site, there are not changes. What could it be?

  10. Guille

    Hey Ania, thank you so much for this tutorial,
    in additon to this i made hook for woo commerce in the shop and product category page

    if ( is_shop())
    if ( is_product_category())

  11. minervewebstudio

    Thank you so much for this tutorial.
    Really nice php function for adding some new stuff in our pages.

  12. mmromanc

    Hi, Ania.
    Loved this tutorial.
    One question: How can I use the same method, but for woocommerce product categories instead of blogcategories? And use the (is_home) for the Shop page?

    • Ania Romańska

      Hi, Here‘s a list of all Woocommerce Template Hooks you can use. A quick Google search for “woocommerce hooks visual guide” will help as well 😉

  13. Rambo Ruiz

    Wow thanks Ania! This is really great! I’m not really good with php just yet and so you showing the steps and “why” was really helpful!

  14. Narwastu Nagoro

    Hi Ania, thanks for all your tutorials. It’s really help me a lot.

  15. BOB

    Great tutorial, will bookmark and if neded will get back to it. Thank you.

  16. Hurri

    Hi Ania,
    As an owner of one of your child themes I know just how great your work is and I always look forward to your snippets of code and layouts to help me tweak my own work.
    Thank you so much for your efforts and keep them coming we all look forward to and appreciate them!

  17. Jason Paulo

    This is a very helpful tutorial! Now we’re being introduced to php.. Thank you Ania! 🙂

  18. Admir Rosa

    Hello Ania!
    I’m brazilian. I was an Adobe Muse user and I currently signed with Blocsapp. Very good but only for Mac! Parallel I decided to invest in WordPress. On the way I found the Divi. I signed Elegant Themes. I study every day. It’s Extraordinary! In Youtube I found your video How to Add Global Footer Using Divi Template Hooks and I was in love with your work. It’s clean, creative, it’s perfect. Congratulations! Later this year I will be participating in your projects with template purchases or donations. Believe me, your work is great! Thank you, Health and Success for you!

    • Ania Romańska

      Hi Admir,
      Thank you so much for your kind words! I really appreciate it. Wish you all the best on your new WordPress and Divi journey 😉


Submit a Comment

Your email address will not be published. Required fields are marked *

Enjoing our content?

You might find this interesting…

License Details


Single Site

A regular license allows an item to be used in one project for either personal or commercial use by you or on behalf of a client. The item cannot be offered for resell either on its own or as a part of a project. Distribution of source files is not permitted.


Unlimited Sites

An extended license allows an item to be used in unlimited projects for either personal or commercial use. The item cannot be offered for resell either on its own or as a part of a project. Distribution of source files is not permitted.


Each license is a one-time payment. There are no annual fees. You get lifetime access to product updates. Support is provided for 6 months from the date of purchase.

Server Requirements


  • PHP 7.2 or later
  • upload_max_filesize (256M)
  • max_input_time (300)
  • memory_limit (256M)
  • max_execution_time (300)
  • post_max_size (512M)


  • php-xml or/and php-dom
  • XMLReader
  • PHP CURL module


  • allow_url_fopen

Would you like to...

Consult Ania and fellow students?

Join the conversation inside our private FB group.

Would you like to...

Get support privately?

Submit a support ticket via your account page.

Ask Ania?

Submit a question for the next live Q&A session.

Consult fellow students?

Join the conversation inside our private FB group.
Identity: New Divi Child Theme Check it out