List Category Posts allows you to list posts by category in a post/page using the [catlist] shortcode. This shortcode accepts a category name or id, t
The plugin can figure out the category from which you want to list posts in several ways. You should use only one of these methods since these are all mutually exclusive, weird results are expected when using more than one:
When using List Category Posts whithout a category id, name or slug, it will post the latest posts from every category.
[catlist id=1+2-3]. Important: When using the and relationship, you should write the categories you want to include first, and then the ones you want to exclude. So
[catlist id=1+2-3]will work, but
To use pagination, you need to set the following parameters:
pagination set it to yes.
numberposts - Posts per page are set with the
instance (only necessary when using the shortcode with pagination more than once in the same page/post) - a number or name to identify the instance where you are using pagination. Since you can use the shortcode several times in the same page or post, you need to identify the instance so that you paginate only that instance.
[catlist id=3 numberposts=5 pagination=yes instance=1]
[catlist id=5 numberposts=15 pagination=yes instance=2]
You can customize what to show for the "next" and "previous" buttons in the pagination navigation. Use the following params:
If you want to customize the way the pagination is displayed, you can
lcp_paginator.css file from the plugin's directory to your
theme's directory and customize it. Do not customize the file on the
plugin's directory since this file will be overwritten every time you
update the plugin.
author_posts - Get posts by author. Use 'user_nicename' (NOT
tags - Tag support, display posts from a certain tag.
currenttags - Display posts from the current post's tags (won't work on pages since they have no tags).
exclude_tags - Exclude posts from one or more tags:
[catlist tags="videogames" exclude_tags="sega,sony"]
orderby - To customize the order. Valid values are:
[catlist name=mycategory orderby=date]
customfield_orderby - You can order the posts by a custom field. For example:
[catlist numberposts=-1 customfield_orderby=Mood order=desc] will list all the posts with a "Mood" custom field. Remember the default order is descending, more on order:
order - How to sort orderby. Valid values are:
[catlist name=mycategory orderby=title order=asc]
starting_with - Get posts whose title starts with a certain
[catlist starting_with="l"] will list all posts
whose title starts with L. You can use several letters:
numberposts - Number of posts to return. Set to 0 to use the max
number of posts per page. Set to -1 to remove the limit.
[catlist name=mycategory numberposts=10]
You can set the default number of posts globally on the options
page on your Dashboard in Settings / List Category Posts.
no_posts_text - Text to display when no posts are found. If you don't specify it, nothing will get displayed where the posts should be.
monthnum and year - List posts from a certain year or month. You can use these together or independently. Example:
[catlist year=2015] will list posts from the year 2015.
[catlist monthnum=8] will list posts published in August of every year.
[catlist year=2012 monthnum=12] will list posts from December 2012.
search - List posts that match a search term.
[catlist search="The Cake is a lie"]
date - Display post's date next to the title. Default is 'no',
use date=yes to activate it. You can set a css class and an html
tag to wrap the date in with
date_tag (see HTML
& CSS Customization further below).
date_modified - Display the date a post was last modified next
to the title. You can set a css class and an html tag to wrap the
date in with
HTML & CSS Customization further below).
author - Display the post's author next to the title. Default is
'no', use author=yes to activate it. You can set a css class and an html
tag to wrap the author name in with
author_tag (see HTML
& CSS Customization further below).
When displaying the post author, you can also display a link to the author's page. The following parameter only works if author=yes is present in the shortcode:
dateformat - Format of the date output. The default format is the one you've set on your WordPress settings. Example:
[catlist id=42 dateformat="l F dS, Y"] would display the date as "Monday January 21st, 2013". Check http://codex.wordpress.org/Formatting_Date_and_Time for more options to display date.
excerpt - Display a plain text excerpt of the post. Default is 'no', use
excerpt=full to activate it. If you have a separate excerpt in your post, this text will be used. If you don't have an explicit excerpt in your post, the plugin will generate one from the content, striping its images, shortcodes and HTML tags. If you want to overwrite the post's separate excerpt with an automatically generated one (may be useful to allow HTML tags), use
If you use
excerpt=yes, the separate excerpt or content will be limited to the number of words set by the excerpt_size parameter (55 words by default).
If you use
excerpt=full the plugin will act more like WordPress. If the post has a separate excerpt, it will be used in full. Otherwise if the content has a <!--more--> tag then the excerpt will be the text before this tag, and if there is no <!--more--> tag then the result will be the same as
If you want the automatically generated excerpt to respect your theme's allowed HTML tags, you should use
excerpt_strip=no, otherwise the HTML tags are automatically stripped.
excerpt_size - Set the number of words to display from the excerpt. Default is 55. Eg:
excerpt_strip - Set it to
yes to strip the excerpt's HTML tags. If the excerpt is auto generated by the plugin, the HTML tags will be stripped, and you should use
excerpt_strip=no to see the excerpt with HTML formatting.
title_limit - Set the limit of characters for the title. Ex:
[catlist id=2 title_limit=50] will show only the first 50
characters of the title and add "…" at the end.
excludeposts - IDs of posts to exclude from the list. Use 'this' to exclude the current post. Ex:
offset - You can displace or pass over one or more initial posts which would normally be collected by your query through the use of the offset parameter.
content - WARNING: If you want to show the content on your listed posts, you might want to do this from a new Page Template or a Custom Post Type template. Using this parameter is discouraged, you can have memory issues as well as infinite loop situations when you're displaying a post that's using List Category Posts. You have been warned. Usage:
Show the excerpt or full content of the post. If there's a <!--more--> tag in the post, then it will behave just as WordPress does: only show the content previous to the more tag. Default is 'no'. Ex:
Show the full content of the post regardless of whether there is a <!--more--> tag in the post. Ex:
catlink - Show the title of the category with a link to the category. Use the catlink_string option to change the link text. Default is 'no'. Ex:
[catlist catlink=yes]. The way it's programmed, it should only display the title for the first category you chose, and include the posts from all of the categories. I thought of this parameter mostly for using several shortcodes on one page or post, so that each group of posts would have the title of that group's category. If you need to display several titles with posts, you should use one [catlist] shortcode for each category you want to display.
catname - Show the title of the category (or categories), works exactly as
catlink, but it doesn't add a link to the category.
category_count - Shows the posts count in that category, only works when using the catlink option:
[catlist name=nintendo catlink=yes category_count=yes]
comments - Show comments count for each post. Default is 'no'. Ex:
thumbnail - Show post thumbnail (http://markjaquith.wordpress.com/2009/12/23/new-in-wordpress-2-9-post-thumbnail-images/). Default is 'no'. Ex:
thumbnail_size - Either a string keyword (thumbnail, medium, large or full) or 2 values representing width and height in pixels. Ex:
[catlist thumbnail_size=32,32] or
thumbnail_class - Set a CSS class for the thumbnail.
post_type - The type of post to show. Available options are: post - Default, page, attachment, any - all post types. You can use several types, example:
[catlist post_type="page,post" numberposts=-1]
post_status - use post status, default value is 'publish'. Valid values:
[catlist post_status="future, publish" excludeposts=this]
show_protected - Show posts protected by password. By default
they are not displayed. Use:
post_parent - Show only the children of the post with this ID. Default: None.
post_suffix - Pass a String to this parameter to display this
String after every post title.
post_suffix="Hello World"] will create something like:
<ul class="lcp_catlist" id=lcp_instance_0>
<a href="http://127.0.0.1:8080/wordpress/?p=42" title="WordPress">
</a> Hello World </li>
display_id - Set it to yes to show the Post's ID next to the post title:
[catlist id=3 display_id=yes]
class - CSS class for the default UL generated by the plugin.
custom fields - To use custom fields, you must specify two values: customfield_name and customfield_value. Using this only show posts that contain a custom field with this name and value. Both parameters must be defined, or neither will work.
customfield_display - Display custom field(s). You can specify
many fields to show, separating them with a coma. If you want to
display just the value and not the name of the custom field, use
customfield_display_name and set it to no.
By default, the custom fields will show inside a div with a
<div class="lcp-customfield">. You can customize
this using the customfield_tag and customfield_class parameters to
set a different tag (instead of the div) and a specific class
(instead of lcp-customfield).
customfield_display_name - To use with
Use it to just print the value of the Custom field and not the
[catlist numberposts=-1 customfield_display="Mood" customfield_display_name="no"]
Will print the value of the Custom Field "Mood" but not the text "Mood: [value]".
template - By default, posts will be listed in an unordered list (ul tag) with the class 'lcp_catlist':
<ul class="lcp_catlist"><li><a href="post1">Post 1</li>...
You can use a different class by using the class parameter.
You can create your own template file (Check Template System
further down this document) and pass it as a parameter here. The
parameter is the template name without the extension. For example
mytemplate.php, the value would be
You can also pass these two parameters which yield different results:
div - This will output a div with the
(or one you pass as a parameter with the
class argument). The
posts will be displayed between p tags.
ol - This will output an ordered list with the
css class (or the one you pass as a parameter with the
argument) and each post will be a list item inside the ordered list.
morelink - Include a "more" link to access the category archive for the category. The link is inserted after listing the posts. It receives a string of characters as a parameter which will be used as the text of the link. Example:
[catlist id=38 morelink="Read more"]
posts_morelink - Include a "read more" link after each post. It receives a string of characters as a parameter which will be used as the text of the link. Example:
[catlist id=38 posts_morelink="Read more about this post"]
link_target - Select the
target attribute for links to posts (target=_blank, _self, _parent, _top, *framename*). Example:
[catlink id=3 link_target=_blank] will create:
<a href="http://localhost/wordpress/?p=45" title="Test post" target="_blank">Test post</a>
no_post_titles - If set to
yes, no post titles will be shown. This may make sense together with
link_titles - Option to display titles without links. If set to
false, the post titles won't be linking to the article.
The widget is quite simple, and it doesn't implement all of the plugin's functionality. To use a shortcode in a widget add this code to your theme's functions.php file:
Then just add a new text widget to your blog and use the shortcode there as the widget's content.
By default, the plugin lists the posts in an unordered list with the
CSS class, like this:
So if you want to customize the appearance of the List Category Posts lists, you can just edit the lcp_catlist class in your theme's CSS.
You can also customize what HTML tags different elements will be
surrounded with, and set a CSS class for this element, or just a CSS class
which will wrap the element with a
The customizable elements (so far) are: author, catlink (category link), comments, date, excerpt, morelink ("Read More" link), thumbnail and title (post title).
The parameters are:
author_tag, author_class, catlink_tag, catlink_class, comments_tag, comments_class, date_tag, date_class, date_modified_tag, date_modified_class, excerpt_tag, excerpt_class, morelink_class, thumbnail_class, title_tag, title_class, posts_morelink_class, customfield_tag, customfield_class
So let's say you want to wrap the displayed comments count with the p tag and a "lcp_comments" class, you would do:
[catlist id=7 comments=yes comments_tag=p comments_class=lcp_comments]
This would produce the following code:
<p class="lcp_comments"> (3)</p>
Or you just want to style the displayed date, you could wrap it with a span tag:
[catlist name=blog date=yes date_tag=span date_class=lcp_date]
This would produce the following code:
<span class="lcp_date">March 21, 2011</span>
Elements without a specified tag, but a specified class, will be wrapped with a span tag and its class. For example this:
[catlist id=7 date=yes date_class="lcp_date"]
Will produce the following:
<span class="lcp_date">October 23, 2013</span>
The only exceptions here are the title_tag and title_class
parameters. If you only use the title_class parameter, the CSS
class will be assigned to the
a tag like this:
[catlist id=1 title_class="lcp_title"]
<a href="http://127.0.0.1/wordpress/?p=38" title="Test" class="lcp_title">Test</a>
But if you use both:
[catlist numberposts=5 title_class=lcp_title tag=h4]
You will get:
<h4 class="lcp_title"> <a title="Hipchat" href="http://127.0.0.1:8080/wordpress/?p=40"></a> </h4>
Templates for the List Category Plugin are searched for in your WordPress theme's folder. You should create a folder named list-category-posts under 'wp-content/themes/your-theme-folder'. Template files are .php files.
You can use the included template as an example to start. It's in the plugin's template folder under the name default.php. To use a template, use this code:
[catlist id=1 template=templatename]
If the template file were templatename.php.
You can have as many different templates as you want, and use them in different pages and posts. The template code is pretty well documented, so if you're a bit familiar with HTML and PHP, you'll have no problems creating your own template. I'm planning on reworking the template system in order to have a really user friendly way to create templates.
Requires: 3.3 or higher
Compatible up to: 4.2.4
Last Updated: 2015-6-10
Active Installs: 100,000+
3 of 65 support threads in the last two months have been resolved.
Got something to say? Need help?