previous_posts_link()与next_post_lnik()这两个函数信任各位wordpress主题开发者必定不生疏,这两个函数是wordpress用来调用当时文章的前一篇以及后一篇文章的。可是有些时分咱们为了进步网站PV进步用户体会想多调用几篇文章,例如调用当时文章的前三篇文章以及后三篇文章那该怎样调用呢?魔客吧查看了下wordpress的官方文档,明显没有现成的代码和函数可用。那么只好自己着手锦衣玉食了。以下代码参阅自wordpress默许函数get_adjacent_post函数修正而来:

functionv7v3_get_post($previous=true,$number=1){

//global当时文章变量$post和数据库操作类wpdb
global$post,$wpdb;
if(empty($post))
returnnull;

$current_post_date=$post->post_date;//当时文章的时刻

$join='';
$posts_in_ex_cats_sql='';
//参加表
$join="INNERJOIN$wpdb->term_relationshipsAStrONp.ID=tr.object_idINNERJOIN$wpdb->term_taxonomyttONtr.term_taxonomy_id=tt.term_taxonomy_id";
//获取当时文章所属分类,能够同属多个分类,如果是自定义的分类法,将category换成对应的分类法即可
$cat_array=wp_get_object_terms($post->ID,'level',array('fields'=>'ids'));
$join.="ANDtt.taxonomy='level'ANDtt.term_idIN(".implode(',',$cat_array).")";

//判别时刻是大于仍是小于
$op=$previous?'<':'>';
//排序
$order=$previous?'DESC':'ASC';

$where=$wpdb->prepare("WHEREp.post_date$op%sANDp.post_type=%sANDp.post_status='publish'",$current_post_date,$post->post_type);
$sort="ORDERBYp.post_date$orderLIMIT0,$number";

$query="SELECTp.*FROM$wpdb->postsASp$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("SELECTp.*FROM$wpdb->postsASp$join$where$sort");
if(null===$result)
$result='';
wp_cache_set($query_key,$result,'counts');
return$result;
}

将该函数放在主题的functions.php文件中即可,调用该函数的时分会回来一个数组,运用示例:

本篇教程之前的几篇教程是ID).'"title="'.$postt->post_title.'">'.$postt->post_title.'';
};
?>本篇教程之后的几篇教程是ID).'"title="'.$postt->post_title.'">'.$postt->post_title.'';
};
?>



声明:有的资源均来自网络转载,版权归原作者所有,如有侵犯到您的权益 请联系邮箱:123456@qq.com 我们将配合处理!

原文地址:wordpress开发教程:获取当前文章的前几篇以及后几篇文章发布于2022-05-13 07:43:29

相关推荐