WooCommerce: Show Related Products In a Blog Post!

Maybe because I’m Italian, but I like exclamation marks! Also, Italian gestures – of course. With that being said, today we look at an amazing WooCommerce customization.

I’ve finally gained back some free time to work on my personal projects, and one of these is an affiliate website. In order to drive traffic to this WooCommerce website, we have a major content strategy and we publish 7 relevant posts per month.

However, it’s difficult to drive blog readers to the shop page, so I came up with a great idea – why not adding a grid of relevant related products at the end of each blog post, based on the most used keywords?

The rationale behind this is quite easy:

  1. you have a list of product tags
  2. you have a blog post full of words
  3. you count and define the most mentioned product tag
  4. you show 10 products from that product tag

Cool, ha? Well, let’s take a look at my code, and feel free to use it on your install!

This blog post is clearly about Sicilian wine, and mentions the word “vino” several times. The snippet below is able to find that out, and add a “Related Products” to the bottom of the blog post with 10 products belonging to the “vino” product tag. Amazing!

PHP Snippet: Show Related Products In a Blog Post Based on The Most Mentioned Product Tag

Important note: right at the beginning of the snippet, you must first build manually (or find an automatic way to build it) an array of “BLOG POST WORD” -> “PRODUCT TAG SLUG” relationships. This is unless your products tag slugs are exactly identical (case sensitive) to the words you want to count inside the blog post.

Other cool stuff inside the snippet:

  • We loop through the array and use substr_count, a cool PHP function that counts how many times a substring is mentioned in a string, to count how many times our “WORDS” (array keys) are mentioned in the blog post content. During the loop I basically use the $max variable to store the greatest count, and in such case I overwrite the $top_tag variable with the current tag slug
  • Once the loop is completed, if at least one tag slug was found, I simply use the WooCommerce [products] shortcode with the “tag” attribute, so that I can get a list of products within that product tag!
/**
 * @snippet       Related Products @ Blog Post
 * @how-to        businessbloomer.com/woocommerce-customization
 * @author        Rodolfo Melogli, Business Bloomer
 * @compatible    WooCommerce 7
 * @community     https://businessbloomer.com/club/
 */

add_filter( 'the_content', 'bbloomer_blog_post_related_products' );

function bbloomer_blog_post_related_products( $text ) {
	if ( is_singular( 'post' ) ) {
		$word_to_tag = array(
			'pasta' => 'pasta-2',
			'pizza' => 'sicilian-pizza',
			'spaghetti' => 'spag',
		);
		$max = 0;
      $top_tag = '';
		foreach ( $word_to_tag as $word => $tag_slug ) {
			if ( substr_count( $text, $word ) > $max ) {
				$max = substr_count( $text, $word );
				$top_tag = $tag_slug;
			}
		}
		if ( $top_tag ) $text .= '<h2>Related Products</h2>' . do_shortcode( '[products columns="5" limit="10" tag="' . $top_tag . '"]' );
	}
	return $text;
}

Where to add custom code?

You should place custom PHP in functions.php and custom CSS in style.css of your child theme: where to place WooCommerce customization?

This code still works, unless you report otherwise. To exclude conflicts, temporarily switch to the Storefront theme, disable all plugins except WooCommerce, and test the snippet again: WooCommerce troubleshooting 101

Related content

Rodolfo Melogli

Business Bloomer Founder

Author, WooCommerce expert and WordCamp speaker, Rodolfo has worked as an independent WooCommerce freelancer since 2011. His goal is to help entrepreneurs and developers overcome their WooCommerce nightmares. Rodolfo loves travelling, chasing tennis & soccer balls and, of course, wood fired oven pizza. Follow @rmelogli

Questions? Feedback? Customization? Leave your comment now!
_____

If you are writing code, please wrap it like so: [php]code_here[/php]. Failure to complying with this, as well as going off topic or not using the English language will result in comment disapproval. You should expect a reply in about 2 weeks - this is a popular blog but I need to get paid work done first. Please consider joining the Business Bloomer Club to get quick WooCommerce support. Thank you!

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