wordpress框架自定义添加page分页功能

文章介绍了如何在WordPress中创建一个自定义的数字分页函数,以适应特定的首页显示需求,特别是当需要对特定分类进行分页时。同时,提供了相应的CSS样式代码以美化分页效果。分页函数考虑了总页数的计算和分页链接的显示,包括首页、上一页、下一页和页码链接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

先来看效果图:

一、在主题目录下的functions.php文件里,添加如下分页函数: 

/**
* 数字分页函数
* 说明:因为wordpress默认仅仅提供简单分页,所以要实现数字分页,需要自定义函数
* @Param bool $isHome   是否为主页
* @Param int $range     数字分页的宽度
* @Return string|empty  输出分页的HTML代码
*/
function number_pagenavi($isHome,$range = 4) {
    global $paged,$wp_query;
    /*如果是首页,则自定义查询*/
    if($isHome){
        $number = $wp_query->post_count;
        //只统计手游、端游、页游三个分类
        $query = new WP_Query(array(
            'category_name' => 'shouyou,duanyou,yeyou',
        ));
        $total = $query->found_posts;//总条数
        $max_page = ceil($total/$number);//总页码
    }else{
        $total = $wp_query->found_posts;//总条数
        if ( !$max_page ) {
            $max_page = $wp_query->max_num_pages;//总页码
        }
    }
    if ( !$max_page ) {
        $max_page = $wp_query->max_num_pages;
    }
    if( $max_page >1 ) {
        echo "<div class='fenye'>"; 
        if( !$paged ){
            $paged = 1;
        }
        if( $paged != 1 ) {
            echo "<a href='".get_pagenum_link(1) ."' class='extend' title='跳转到首页'>首页</a>";
        }else{
            echo "<a class='extend' style='color:#ccc;'>首页</a>";
        }
        previous_posts_link('上一页');
        if ( $max_page >$range ) {
            if( $paged <$range ) {
                for( $i = 1; $i <= ($range +1); $i++ ) {
                    echo "<a href='".get_pagenum_link($i) ."'";
                if($i==$paged) echo " class='current'";echo ">$i</a>";
                }
            }elseif($paged >= ($max_page -ceil(($range/2)))){
                for($i = $max_page -$range;$i <= $max_page;$i++){
                    echo "<a href='".get_pagenum_link($i) ."'";
                    if($i==$paged)echo " class='current'";echo ">$i</a>";
                    }
                }elseif($paged >= $range &&$paged <($max_page -ceil(($range/2)))){
                    for($i = ($paged -ceil($range/2));$i <= ($paged +ceil(($range/2)));$i++){
                        echo "<a href='".get_pagenum_link($i) ."'";if($i==$paged) echo " class='current'";echo ">$i</a>";
                    }
                }
            }else{
                for($i = 1;$i <= $max_page;$i++){
                    echo "<a href='".get_pagenum_link($i) ."'";
                    if($i==$paged)echo " class='current'";echo ">$i</a>";
                }
            }
        next_posts_link('下一页');
        if($paged != $max_page){
            echo "<a href='".get_pagenum_link($max_page) ."' class='extend'  title='跳转到最后一页'>尾页</a>";
        }else{
            echo "<a class='extend' disabled='disabled' style='color:#ccc;' >尾页</a>";
        }
        echo '<span style="margin-left:10px;">共'.$max_page.'页</span>';
        echo "</div>\n";  
    }
}

我这个函数是按网站需求做了一些调整和修改,因为我首页只显示三个分类,直接用$wp_query->max_num_pages查总页码的话是不准的,所以你要根据自己的网站数据来调整这个函数的代码。

二、在公共的css文件里添加样式,代码如下:

/*------------------
    分页部分的CSS
------------------*/
.fenye{    
    text-align: center;
    height: 25px;
    line-height: 25px;
    _background: #F9F9F9;
    padding: 2px 5px;
    margin: 20px 4px;
    _border: solid 1px #ccc;
    _text-align: center;
}

.fenye a{
    padding:4px 6px 4px 6px;
    margin:0 2px 0 2px;
    border:1px solid #aaa;
    text-decoration:none;
    color:#333;
    cursor: pointer;
}

.fenye a.current{    
    background:#ff6f3d;    
    color:#fff;
}

.fenye a:hover{
    background:#ff6f3d;
    color:#fff;
}

/*-- footer --*/
.footer {
    width:100%;
    height:64px;
    background:#E6E9ED;
    border-top: 1px solid #e2e2e3;
}


/*-- post --*/
.post {
    background:none;
}

.post .entry-cnt {
    height:auto;
    line-height:2;
    font-size:14px;
    border-top-width: 1px;
    border-top-style: dotted;
    border-top-color: #eee;
    padding:15px 0 0;
}

.post .entry-cnt p {
    line-height:2;
    font-size:14px;    
}

.related {
    padding:10px 5px 10px 5px;
    border-top:1px solid #eee;
    border-bottom:1px solid #eee;
    margin: 20px auto 10px auto;
}

.r-left {
    float:left;
}

.r-right {
    float:right;
}

/*-- discuss --*/
.discuss {
    padding:25px;
}

三、在需要使用分页的位置,插入以下代码:

<!-- 插入分页功能 -->
<?php number_pagenavi(false); ?>

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值