WordPress 单页面上一页下一页的实现方法【附代码】

wordpress文章页页有实现上一篇下一篇功能函数,不过我们想在单页page.PHP里面实现上一页下一页功能,prevIoUs_post_link()和next_post_link() 函数还不能完全满足我的需要,所以就自己写函数实现。 页面有分级功能,需求是按 menu order 排序的子级页面之间有上一篇下一篇链接,如:

Themes(父级页面) ---- zBench(子级页面1) ---- zBorder(子级页面2) ---- zSofa(子级页面3)

如果当前页面是 zBorder,那么就要上一篇链接是 zBench 的,下一篇链接是 zSofa 的。

/**

  • get subpage previous/next page link by zwwooooo
    */
    function subpage_nav_link($prevText='',$nextText='') {
    global $post;
    if ( !$post->post_parent ) return null; //如果不是子页面返回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 ($pages as $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 = '<a class="previous-page-link" href="' . get_page_link($prev->ID). '">' . $prevText . '';
    }
    if ($next) {
    if ($nextText) {
    if ( substr_count($nextText,$nextText);
    $nextText = $explode[0] . get_the_title($next->ID) . $explode[1];
    }
    } else {
    $nextText = get_the_title($next->ID);
    }
    $nextlink = '<a class="next-page-link" href="' . get_page_link($next->ID). '">' . $nextText . '';
    }
    return array($prevlink,$nextlink);
    }

[函数]

subpage_nav_link($prevText,$nextText)

[参数]

$prevText: 为前一篇文章链接文字,为空时认是页面标题 $nextText: 为下一篇文章链接文字,为空时认是页面标题

例如:一般的主题是在 page.PHP 的 loop 循环里面(不知道就在 the_content(); 下面吧)插入调用代码

代码如下:

注:可以用 if (!$subpage_nav_link[0]) 来判断有没有上一篇,同样 if (!$subpage_nav_link[1]) 来判断有没有下一篇

PS: $prevText 和 $nextText 还支持字符组合,如 subpage_nav_link('oo %title xx','') 这样的话,前一篇文章链接文章会变成“oo 页面名 xx”

另一篇实用文章:实现wordpress文章页调用分类上/下一篇文章

wordpress提供的显示上一篇下一篇文章函数代码是按照发布顺序调用的,前几天做的wordpress小说模板,由于使用每个分类添加一部小说《博客吧首款wordpress小说网站主题模板wpnovel》,如果使用这样的上下篇文章调用顺序显示不合适,让文章页显示分类下的上一篇下一篇文章才是正道,wordpress是强大的,总能满足用户的想法,通过搜索找到了相关的函数代码

认直接调用代码

文章处于首篇或末篇时,会显示空白,但可以通过增加判断还填补空白

经过测试虽然显示分类下的文章,但首篇文章和末尾的文章不显示对应的提示信息“已是最后文章”和“已是最后文章”。只要在get_prevIoUs_post()函数中指定一下文章所属分类ID便能使代码完全有效。

下面是完整的代码

代码如下:
term_id); } $categoryIDS = implode(",",$categoryIDS); ?>
打开主题目录下的文章页single.PHP,在要显示的位置添加代码,保存文件即可。

以上这篇wordpress页面上一页下一页实现方法【附代码】就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...