最近准备对主题默认的首页样式进行修改,做成一个类似 CMS 的布局,我们做 cms 杂志模板的时候,经常会用到一次性分别循环输出几个分类的最新文章(如下图显示的效果),虽然目前 WordPress 还没有直接实现这样功能的函数,但是经过加入一点 php 代码,一样可以轻松实现这样的功能,所以不要小看 WordPress,它与一般的 cms 程序一样强大!
那么如何让 WordPress 一次性输出几个分类的最新文章,其实逻辑思路很简单,就是两层循环机构。下面直接贴出来我找到的代码吧,大家自己研究。实现方法,请看源码吧,里面嵌套的很多代码都是可以修改的,特别是 html 标签,请灵活运用!
<?php
$loop_cate_id=array(1,3,8); //指定要输出的分类id
$num=10;//指定每次循环输出的文章篇数
?>
<div class="main-list clearfix">
<?php foreach($loop_cate_id as $key=>$value){ ?>
<div id="box-<?php echo $key; ?>" class="box">
<?php $posts = query_posts($query_string . "&cat={$value}&orderby=date&showposts={$num}" ); ?>
<h2><a href="<?php echo get_category_link($value); ?>"><?php single_cat_title(); ?></a></h2>
<ul>
<?php while(have_posts()) : the_post(); ?>
<li><a href="<?php the_permalink() ?>" rel="bookmark" title="<?php the_title(); ?>"><?php the_title(); ?></a> </li>
<?php endwhile; ?>
</ul>
</div>
<?php }?>
</div>
我这初步实现了效果,但是总感觉还有优化的空间,那么补充一个优化过得代码:
<?php
$terms = get_terms($args = array('taxonomy' => 'category', 'hide_empty' => true));
// 循环输出分类
foreach ($terms as $term) {
$posts = get_posts(array('cat' => $term->term_id, 'post_type' => 'post'));
?>
<div class="container">
<div class="lb_mc"><a href="<?php echo get_term_link($term); ?>"><?php echo $term->name; ?><span>查看更多>></span></a></div>
<div class="lb_zs row">
<ul>
<?php
/**
*@循环输出文章列表
*/
foreach ($posts as $post) {
echo '<li class="col-lg-3 col-md-3 col-sm-4 col-xs-6">';
echo '<a href="'.get_the_permalink($post).'">'.get_the_title($post) .'</a>';
echo '</li>';
}
?>
</ul>
</div>
</div>
<?php
}
unset($term);
?>
根据个人情况来使用吧,在补充一个 WordPress 循环输出当前分类下子分类及其目录最新文章:
//WordPress循环输出当前父分类所有子分类及其目录最近文章
<?php
$i = 0; // 仅为奇偶项 class 作准备
$categories = get_categories('child_of='. $cat .'&depth=0&hide_empty=0&orderby=id&order=asc');// 找出其所有子分类,并按ID号升序排列,其实这里还可以使用数组array(8,9,11,12)输出指定id的分类。
$num=5;//指定每次循环输出的文章篇数
foreach ($categories as $category) { // 开始循环子分类
$now_cat = $category->term_id; // 子分类ID
//$cat_name = $category->cat_name; // 子分类名称
?>
<?php $posts = query_posts("&cat={$now_cat}&orderby=date&showposts={$num}" );//这个子凡就不解释了,相信你看得懂,嘿嘿 ?>
<h2>
<strong><?php single_cat_title(); ?></strong><!--其实这里用single_cat_title()和用变量$cat_name都可以了-->
<a href="<?php echo get_category_link($category); ?>" target="_blank">More...</a>
</h2>
<div id="shows">
<ul>
<?php while(have_posts()) : the_post(); ?>
<li id="cat_<?php echo $now_cat; ?>" class="item<?php echo $i%2 . ' ' . $category->slug; ?>"> <!-- $i%2 实现不同的class区别奇偶项($i在循环体末尾循环递增), $category->slug 区别不同分类 —— 这样你可以为每个分类列表定义不同的样式 -->
<a href="<?php the_permalink(); ?>" target="_blank"><?php the_title(); ?>
</li>
<?php endwhile; ?>
</ul>
</div>
<?php $i++; }//$i实现递增?>
当然,这段代码主要还是提供一种思路,如果使用建议为父级分类新建一个模板文件(category-news.php,比如 news 是你的父分类目录的别名)。
专业提供WordPress主题安装、深度汉化、加速优化等各类网站建设服务,详询在线客服!