WordPress 单页面上一页下一页的实现方法【附代码】
WordPress的文章页页有实现上一篇下一篇的功能函数,不过我们想在单页page.php里面实现上一页下一页的功能,previous_post_link()和next_post_link()函数还不能完全满足我的需要,所以就自己写函数实现。
页面有分级功能,需求是按menuorder排序的子级页面之间有上一篇、下一篇链接,如:
Themes(父级页面)
----zBench(子级页面1)
----zBorder(子级页面2)
----zSofa(子级页面3)
如果当前页面是zBorder,那么就要上一篇链接是zBench的,下一篇链接是zSofa的。
把下面函数代码放入functions.php(注:函数随手写的,可能不够精简) /** *getsubpageprevious/nextpagelinkbyzwwooooo */ functionsubpage_nav_link($prevText='',$nextText=''){ global$post; if(!$post->post_parent)returnnull;//如果不是子页面返回Null $args=array( 'sort_order'=>'ASC', 'sort_column'=>'menu_order', 'child_of'=>$post->post_parent, 'post_type'=>'page' ); $pages=get_pages($args); $num=count($pages); $i=0; $index=-1; foreach($pagesas$page){ if($page->ID==$post->ID){ $index=$i; break; } ++$i; } if($i==0){ $prev=''; $next=$pages[$index+1]; }elseif($i==$num-1){ $prev=$pages[$index-1]; $next=''; }else{ $prev=$pages[$index-1]; $next=$pages[$index+1]; } if($prev){ if($prevText){ if(substr_count($prevText,'%title')>0){ $explode=explode('%title',$prevText); $prevText=$explode[0].get_the_title($prev->ID).$explode[1]; } }else{ $prevText=get_the_title($prev->ID); } $prevlink='<aclass="previous-page-link"href="'.get_page_link($prev->ID).'">'.$prevText.'</a>'; } if($next){ if($nextText){ if(substr_count($nextText,'%title')>0){ $explode=explode('%title',$nextText); $nextText=$explode[0].get_the_title($next->ID).$explode[1]; } }else{ $nextText=get_the_title($next->ID); } $nextlink='<aclass="next-page-link"href="'.get_page_link($next->ID).'">'.$nextText.'</a>'; } returnarray($prevlink,$nextlink); }
[函数]
subpage_nav_link($prevText,$nextText)
[参数]
$prevText:为前一篇文章链接文字,为空时默认是页面标题
$nextText:为下一篇文章链接文字,为空时默认是页面标题;
例如:一般的主题是在page.php的loop循环里面(不知道就在the_content();下面吧)插入调用代码
<?php if(function_exists('subpage_nav_link')){ if($subpage_nav_link=subpage_nav_link()){ echo$subpage_nav_link[0];//上一篇(页面)链接 echo$subpage_nav_link[1];//下一篇(页面)链接 } } ?>
注:可以用if(!$subpage_nav_link[0])来判断有没有上一篇,同样if(!$subpage_nav_link[1])来判断有没有下一篇。
PS:$prevText和$nextText还支持字符组合,如subpage_nav_link('oo%titlexx','')这样的话,前一篇文章链接文章会变成“oo页面名xx”
另一篇实用文章:实现wordpress文章页调用同分类上/下一篇文章
wordpress提供的显示上一篇、下一篇文章的函数代码是按照发布顺序调用的,前几天做的wordpress小说模板,由于使用每个分类添加一部小说《博客吧首款wordpress小说网站主题模板wpnovel》,如果使用这样的上下篇文章调用顺序显示不合适,让文章页显示同分类下的上一篇、下一篇文章才是正道,wordpress是强大的,总能满足用户的想法,通过搜索找到了相关的函数代码。
默认直接调用的代码
<?phpprevious_post_link('上一篇:%link')?>
<?phpnext_post_link('下一篇:%link')?>
当文章处于首篇或末篇时,会显示空白,但可以通过增加判断还填补空白
<?phpif(get_previous_post()){previous_post_link('上一篇:%link');}else{echo"已是最后文章";}?>
<?phpif(get_next_post()){next_post_link('下一篇:%link');}else{echo"已是最新文章";}?>
经过测试虽然显示同分类下的文章,但首篇文章和末尾的文章会不显示对应的提示信息“已是最后文章”和“已是最后文章”。只要在get_previous_post()函数中指定一下文章所属分类ID便能使代码完全有效。
下面是完整的代码:
<?php $categories=get_the_category(); $categoryIDS=array(); foreach($categoriesas$category){ array_push($categoryIDS,$category->term_id); } $categoryIDS=implode(",",$categoryIDS); ?> <?phpif(get_previous_post($categoryIDS)){previous_post_link('上一篇:%link','%title',true);}else{echo"已是最后文章";}?> <?phpif(get_next_post($categoryIDS)){next_post_link('上一篇:%link','%title',true);}else{echo"已是最新文章";}?>
打开主题目录下的文章页single.php,在要显示的位置添加代码,保存文件即可。
以上这篇WordPress单页面上一页下一页的实现方法【附代码】就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。