WooCommerce Product Price Shortcode

Written by Dan Mossop

Here's the PHP code for adding a custom shortcode to your site, which will output the price of a given WooCommerce product:
add_shortcode('db_wc_product_price', 'db_wc_product_price');

function db_wc_product_price($atts)
{
	if (!function_exists('wc_get_product') || !function_exists('get_woocommerce_currency_symbol')) return '';
	if (empty($atts['id'])) return '';
	$product = wc_get_product($atts['id']);
	if (!$product) return '';
	return get_woocommerce_currency_symbol().$product->get_price();
}

This is based on a similar shortcode by WP Beaches. The main difference here is that that shortcode outputs the price wrapped in some HTML, while the version above returns just the plain text of the price and currency symbol. This is useful in cases where the HTML (and with it the price) would be rejected / stripped out by validation code.

It is used like so:

 [db_wc_product_price id="10"]

Unlock the Full Potential of Shortcodes in Divi!

Empower your Divi site with the Divi Shortcode Enabler. This plugin allows shortcodes to run effortlessly in various Divi module fields, enhancing functionality and customization across your site.

About Dan Mossop

Dan is a Scottish-born web developer, now living in Brisbane with his wife and son. He has been sharing tips and helping users with Divi since 2014. He created Divi Booster, the first Divi plugin, and continues to develop it along with 20+ other Divi plugins. Dan has a PhD in Computer Science, a background in web security and likes a lot of stuff, 

2 Comments

  1. Thank you for guidance. But I want to get the price of the product to include in the article. When I change the price in the product, the price in the article also changes. So do it like this?

    Reply
    • Hey Dzung, if I understand you correctly then yes, this shortcode should do what you need. You should be able to use the shortcode in a text module (for example) in among the text of your article. It will grab the latest price each time the page is viewed, so will automatically update when the product price changes. One thing to note though is that if the page with the article is cached it may take some time for the price change to be reflected in the article. You could get round this by 1) disabling caching on the page, 2) setting a sufficiently short caching time on the page, or 3) clearing the cache whenever you chance the price. I hope that helps!

      Reply

Submit a Comment

Comments are manually moderated and approved at the time they are answered. A preview is shown while pending but may disappear if your are cookies cleared - don't worry though, the comment is still in the queue.

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

We may earn a commission when you visit links on our website.

Latest Posts

Set Custom CSS IDs for Individual Divi Accordion Items

Assigning unique CSS IDs to specific Divi Accordion items allows for precise control over styling, targeting, and linking within your page content. This ability is particularly useful when you want to apply custom designs or create anchor links to particular accordion...

Enable Swipe Navigation in the Divi Gallery Lightbox

Enabling swipe navigation in the Divi Gallery module's lightbox allows users to seamlessly browse through gallery images by swiping left or right, creating a more interactive and mobile-friendly experience. This functionality can significantly improve user engagement...

Disable Slide-In Animation for Divi Gallery Grid Images

Control how images appear in your Divi Gallery module by toggling the slide-in animation effect for grid layouts. Disabling the slide-in animation allows gallery images to load instantly and appear statically, providing a faster and distraction-free browsing...

Control Image Count Display in Divi Gallery Lightbox

Displaying or hiding the image count in the Divi Gallery module’s lightbox can help customize the user experience, depending on whether you want to give visitors an indication of gallery progress or prefer a cleaner, distraction-free view. The ability to toggle this...

Hide Gallery Image Titles in the Divi Lightbox Overlay

Displaying image titles in the lightbox overlay of the Divi Gallery module can sometimes be distracting or unnecessary, depending on your website’s design and user experience goals. Hiding these titles creates a cleaner and more focused viewing experience for visitors...

Random Posts