<ul id="menu-secondary-menu-1" class="amp-menu"><li class="menu-item menu-item-type-post_type menu-item-object-page menu-item-308 "><a href="https://www.websourceblog.com/expertise/" class="dropdown-toggle" data-toggle="dropdown">Expertise – Full Stack Developer</a></li> <li class="menu-item menu-item-type-post_type menu-item-object-page menu-item-178 "><a href="https://www.websourceblog.com/contact-us/" class="dropdown-toggle" data-toggle="dropdown">Contact Us</a></li> <li class="menu-item menu-item-type-post_type menu-item-object-page menu-item-privacy-policy menu-item-1580 "><a href="https://www.websourceblog.com/privacy-policy/" class="dropdown-toggle" data-toggle="dropdown">Privacy Policy</a></li> <li class="menu-item menu-item-type-custom menu-item-object-custom menu-item-has-children menu-item-1606 link-menu"><a href="#"on="tap:AMP.setState({ offcanvas_menu: false })" role="button " tabindex="0" class="dropdown-toggle" data-toggle="dropdown">Hosting Services</a> <input type="checkbox" id="drop-3"><label for="drop-3" class="toggle"></label><ul class="sub-menu"> <li class="menu-item menu-item-type-post_type menu-item-object-page menu-item-1607 "><a href="https://www.websourceblog.com/dreamhost-best-hosting-provider/">DreamHost: A Complete Web Hosting Solution</a></li> <li class="menu-item menu-item-type-post_type menu-item-object-page menu-item-1614 "><a href="https://www.websourceblog.com/digitalocean-a-gateway-to-cloud-simplicity/">DigitalOcean: A Gateway to Cloud Simplicity</a></li> </ul> </li> </ul>

WordPress

How to create custom shortcode in WordPress?

Shortcode in WordPress.

In WordPress we can create custom shortcodes and we can show its output anywhere on the site. To create a shortcode, we will use WordPress built in function add_shortcode(), this function required two parameters, first “shortcode” and others “callback function”; callback function is the function that we will create in theme’s functions.php file.

function theme_name_movies_shortcode($atts = [])
{
$a = shortcode_atts( array(
    'no_of_posts' => 5,
    'title' => "Movies List"
), $atts );
 
$the_query = new WP_Query( array(
    'post_type' => 'movies',
    'posts_per_page' => $a['no_of_posts'],
));
if ( $the_query->have_posts() ) : ?>
    <h2><?php echo $a['title']?></h2>
  <ul>
   <?php while ( $the_query->have_posts() ) : $the_query->the_post(); ?>
       <li><a href="<?php echo get_permalink($the_query->ID)?>"><?php the_title(); ?></a></li>
   <?php
   endwhile;
    ?>
  </ul>
   <?php wp_reset_postdata();
else :
    __('No Movies');
endif;
 
}
add_shortcode(“movies_list”, “theme_name_movies_shortcode”);

For reference, check following function, suppose there is custom post type named “movies” and you want to show movie list in sidebar.

Now you can use “movies_list” shortcode in your website as following ways.

// Use shortcode in a PHP file. 
echo do_shortcode( '[movies_list no_of_posts="5" title="Movies"]' ); 

Or you can add following statement in “text” widget.

[movies_list no_of_posts="5" title="Latest Films"]

That’s it. Hope this will help.

websourceblog

ReactJs, NodeJs, Amazon Web Services, Symfony, Laravel, CodeIgniter, Zend Framework, WordPress, Drupal, Magento, Angular

Recent Posts

How to install and configure Apache2 on WSL2?

I hope you already have WSL2 installed and enabled. So, setting up Apache2 on WSL2…

3 months ago

How to install NVM on Windows?

Install NVM on Windows Node Js is a JavaScript runtime environment used widely in today’s…

4 months ago

How to reset WSL 2 user’s password?

You can easily reset WSL 2 users' password, by just following the following steps. Open…

8 months ago

DreamHost Web Hosting

DreamHost a web hosting company, founded in 1997. It is offering sort of hosting services,…

1 year ago

How to add submenu or menu in any specific menu option in WordPress programmatically?

Menus in WordPress are highly versatile and can be easily modified to change in your…

1 year ago

Laravel 8 error target class controller does not exist.

Laravel is famous and robust PHP framework, widely used in different type of projects. While…

2 years ago