wordpress获取当前文章的前几篇以及后几篇文章
wordpress 中有默认的调用前一篇后一篇文章的函数 previous_posts_link()与next_post_lnik(),在文章中直接调用方法即可,这在 wordpress 中是很容易实现的,但如果我们需要调用前几篇或者是后几篇的文章,应该怎么办呢,这在 wordpress 中是没有提供方法的,只能自己来添加函数方法了,参考 get_adjacent_post函数,方法如下:
function get_post( $previous = true, $number = 1 ) {
//global当前文章变量 $post 和数据库操作类wpdb
global $post, $wpdb;
if ( empty( $post ) )
return null;
$current_post_date = $post->post_date;//当前文章的时间
//04IE.COM
$join = '';
$posts_in_ex_cats_sql = '';
//加入表
$join = " INNER JOIN $wpdb->term_relationships AS tr ON p.ID = tr.object_id INNER JOIN $wpdb->term_taxonomy tt ON tr.term_taxonomy_id = tt.term_taxonomy_id";
//获取当前文章所属分类,可以同属多个分类,如果是自定义的分类法,将category换成对应的分类法即可
$cat_array = wp_get_object_terms($post->ID, 'level', array('fields' => 'ids'));
$join .= " AND tt.taxonomy = 'level' AND tt.term_id IN (" . implode(',', $cat_array) . ")";
//判断时间是大于还是小于
$op = $previous ? '<' : '>';
//排序
$order = $previous ? 'DESC' : 'ASC';
$where = $wpdb->prepare("WHERE p.post_date $op %s AND p.post_type = %s AND p.post_status = 'publish' ", $current_post_date, $post->post_type);
$sort = "ORDER BY p.post_date $order LIMIT 0, $number";
$query = "SELECT p.* FROM $wpdb->posts AS p $join $where $sort";
$query_key = 'adjacent_post_' . md5($query);
$result = wp_cache_get($query_key, 'counts');
if ( false !== $result )
return $result;
$result = $wpdb->get_results("SELECT p.* FROM $wpdb->posts AS p $join $where $sort");
if ( null === $result )
$result = '';
wp_cache_set($query_key, $result, 'counts');
return $result;
}
同样的需要将本函数加入到主题 functions 文件中,在前台PHP中调用的代码如下所示:
<h4>本篇教程之前的几篇教程是</h4>
<ul>
<?php
$preposts = get_post(true,3);
foreach( $preposts as $postt ){
echo '<li><a href="'.get_permalink($postt->ID).'" title="'.$postt->post_title .'">'.$postt->post_title .'</a></li>';
};
?>
</ul>
<h4>本篇教程之后的几篇教程是</h4>
<ul>
<?php
$nextposts = get_post(false,3);
foreach( $nextposts as $postt ){
echo '<li><a href="'.get_permalink($postt->ID).'" title="'.$postt->post_title .'">'.$postt->post_title .'</a></li>';
};
?>
</ul>
这样就实现了调用多篇文章的功能。
我的网站也是wp制作的 就是有点卡,顶下博主 不过有没有自带的api获取啊
好好优化一下博客,速度也会很快的。
学习了,代码这东西有点复杂
我又来了,还给前辈带来了一份站长福利[给力],回访就有,相信不会让您失望的,静候移驾!
已经回访,看一下什么福利。