Custom pagination

时间:2014-03-12 作者:trikuin

我使用模板部分来显示投资组合项目。它不是页面模板,只是公文包。php文件,我将其包含在get_template_part(\'portfolio\'); 至主页。

现在一切都很好。但我想对这个部分使用分页。这是我的代码块;

<?php
global $wp_query;
$paged = get_query_var(\'paged\') ? get_query_var(\'paged\') : 1;
$port_args = array(
        \'post_type\'     => \'portfolio\',
        \'posts_per_page\'  => 3,
        \'post_status\'     => \'publish\',
        \'paged\'       => $paged
);
$wp_port_query = new WP_Query($port_args);

if( have_posts() ) :
    while ( $wp_port_query->have_posts() ) : $wp_port_query->the_post();
        ?>
        <li class="col-lg-4 col-sm-4 view item <?php $terms = get_the_terms( get_the_ID(), \'portfolio_filter\' ); ?><?php if($terms) : foreach ($terms as $term) { echo $term->slug.\' \'; } endif; ?>">

            <?php the_post_thumbnail("portfolio-image"); ?>

        </li>
        <?php
    endwhile;
endif;

echo \'<nav>\';
echo  \'<div>\'.get_next_posts_link(\'Older\', $wp_port_query->max_num_pages).\'</div>\'; //Older Link using max_num_pages
echo  \'<div>\'.get_previous_posts_link(\'Newer\', $wp_port_query->max_num_pages).\'</div>\'; //Newer Link using max_num_pages
echo "</nav>";

wp_reset_query();
?>
当我单击旧的分页按钮时?paged=2, 但它不起作用,它再次显示相同的帖子。如果我使用页面模板并打开themename/page_id=82 它直接起作用了。url如下所示?page_id=82&paged=2 现在我想我在节中缺少了页面id。如何修复此问题并在主页模板部分使用它。如果不起作用,如何在get\\u next\\u posts\\u链接中添加page\\u id。现在是这样的?paged=2 我想这样改变它?page_id=82&paged=2. 页面id自动来自页面。我该怎么做?

1 个回复
最合适的回答,由SO网友:WpMania.Net 整理而成

我只是稍微修改了一下您的代码以添加分页。。。。给你。。。。

这将是您自定义的帖子类型循环。。。。

<?php if ( get_query_var(\'page\') ) {  $paged = get_query_var(\'page\'); } else if ( get_query_var(\'paged\') ) {  $paged = get_query_var(\'paged\'); } ?>
<?php $LoopPortfolio = new WP_Query(array( \'post_type\' => \'portfolio\', \'paged\'=>$paged, \'posts_per_page\' => \'3\' )); ?>
<?php if($LoopPortfolio->have_posts()) : while($LoopPortfolio->have_posts()) : $LoopPortfolio->the_post(); ?>

    <li class="col-lg-4 col-sm-4 view item <?php $terms = get_the_terms( get_the_ID(), \'portfolio_filter\' ); ?><?php if($terms) : foreach ($terms as $term) { echo $term->slug.\' \'; } endif; ?>">

        <?php the_post_thumbnail("portfolio-image"); ?>

    </li>

<?php endwhile;
pagination($LoopPortfolio->max_num_pages); 
endif; wp_reset_query(); ?>
在函数中添加此函数。php文件。。。。

/// pagination
function pagination($pages = \'\', $range = 2)
{  
     $showitems = ($range * 2)+1;  

     if ( get_query_var(\'page\') ) {
    $paged = get_query_var(\'page\');
} else if ( get_query_var(\'paged\') ) {
    $paged = get_query_var(\'paged\');
} else {
    $paged = 1;
}
     if(empty($paged)) $paged = 1;

     if($pages == \'\')
     {
         global $wp_query;
         $pages = $wp_query->max_num_pages;
         if(!$pages)
         {
             $pages = 1;
         }
     }   

     if(1 != $pages)
     {
         echo "<div class=\\"pagination\\"><span>Page ".$paged." of ".$pages."</span>";
         if($paged > 2 && $paged > $range+1 && $showitems < $pages) echo "<a href=\'".get_pagenum_link(1)."\'>&laquo; First</a>";
         if($paged > 1 && $showitems < $pages) echo "<a href=\'".get_pagenum_link($paged - 1)."\'>&lsaquo; Previous</a>";

         for ($i=1; $i <= $pages; $i++)
         {
             if (1 != $pages &&( !($i >= $paged+$range+1 || $i <= $paged-$range-1) || $pages <= $showitems ))
             {
                 echo ($paged == $i)? "<span class=\\"current\\">".$i."</span>":"<a href=\'".get_pagenum_link($i)."\' class=\\"inactive\\">".$i."</a>";
             }
         }

         if ($paged < $pages && $showitems < $pages) echo "<a href=\\"".get_pagenum_link($paged + 1)."\\">Next &rsaquo;</a>";  
         if ($paged < $pages-1 &&  $paged+$range-1 < $pages && $showitems < $pages) echo "<a href=\'".get_pagenum_link($pages)."\'>Last &raquo;</a>";
         echo "</div>\\n";
     }
}
在CSS文件中添加此CSS。。。。。

/*******************/
.pagination {
clear:both;
padding:20px 0;
position:relative;
font-size:11px;
line-height:13px;
}

.pagination span, .pagination a {
display:block;
float:left;
margin: 4px 4px 4px 0;
padding:9px 12px 8px 12px;
text-decoration:none;
width:auto;
color:#fff;
background: #555;
}

.pagination a:hover{
color:#fff;
background: #3279BB;
}

.pagination .current{
background: #3279BB;
color:#fff;
}
您甚至可以将此代码用于主页(当自定义页面设置为主页时,分页通常不起作用)。因此,只需调用页面两次就可以解决此问题。如果你仍然需要帮助,请与我联系,如果我有时间,我必须帮助你。

结束

相关推荐

Pagination for user list

我使用get_user() 作用但我需要把结果分页。我试了很多,但没有成功。下面是代码,它没有按预期工作:$args = array( \'meta_query\' => array( array( \'key\' => \'ib_s2member_custom_fields\', \'value\' => trim($_GET[\"country\"]), \'compare\' => \