我知道这篇文章有点老了......但是如果它有助于某人的帮助,那么也很好。我尝试使用WP Paginate插件,它没有为我做好杰克,所以我用这个替代方案解决了我所有的问题。
HTML/PHP:
<?php
//Fix homepage pagination
if (get_query_var('paged')) { $paged = get_query_var('paged'); } else if (get_query_var('page')) {$paged = get_query_var('page'); } else {$paged = 1; }
$temp = $wp_query; // re-sets query
$wp_query = null; // re-sets query
$args = array('post_type' => array('assignment', 'student-post'), 'orderby' => 'date', 'order' => 'DESC','posts_per_page' => 15, 'paged' => $paged);
$wp_query = new WP_Query();
$wp_query->query($args);
while ($wp_query->have_posts()) : $wp_query->the_post();
?>
这样几件事情。一个它检查你的家庭,网页或单身,并告诉$ paged变量如何反过来反应。它还允许您使用自定义帖子类型查询您的分页。另外通过不使用query_post,你可以避免使用它时有时得到的一些非常时髦的东西。
里面你的functions.php
function paginate() {
global $wp_query, $wp_rewrite;
$wp_query->query_vars['paged'] > 1 ? $current = $wp_query->query_vars['paged'] : $current = 1;
$pagination = array(
'base' => @add_query_arg('page','%#%'),
'format' => '',
'total' => $wp_query->max_num_pages,
'current' => $current,
'show_all' => true,
'type' => 'list',
'next_text' => '»',
'prev_text' => '«'
);
if($wp_rewrite->using_permalinks())
if (is_home()) {
//fixes index.php weird error on how it displays the pagination URL which causes errors only on index.php
$pagination['base'] = user_trailingslashit(trailingslashit(remove_query_arg('s', get_pagenum_link(1))) . '?page=%#%/', 'paged');
} else {
$pagination['base'] = user_trailingslashit(trailingslashit(remove_query_arg('s', get_pagenum_link(1))) . 'page/%#%/', 'paged');
}
if(!empty($wp_query->query_vars['s']))
$pagination['add_args'] = array('s' => get_query_var('s'));
echo paginate_links($pagination);
}
这最初来自http://bavotasan.com/2011/simple-pagination-for-wordpress/我稍微改装它来获得分页到主页上的工作。
这又一次做了几件事。它为您的页面分页,每个页面都有自己的链接(我觉得很好),并且它还重写了URL以允许使用漂亮的固定链接。出于某种原因,wordpress在index.php上提供了一个404页面,所以我改变了'page /%#%/','paged');到'?page =%#%/','paged');并将其包装在is_home()的条件中。这解决了我的问题与分页和漂亮的固定链接。
分页的可选择定型
ul.page-numbers {
margin: 20px 0 10px;
width: 100%;
padding: 0;
font-size: 12px;
line-height: normal;
clear: both;
float: left;
}
ul.page-numbers li {
float: left;
}
ul.page-numbers a,
ul.page-numbers span {
border-radius: 3px;
-moz-border-radius: 3px;
-webkit-border-radius: 3px;
background: -webkit-gradient(linear, left top, left bottom, from(#E4E3E3), to(#FFFFFF));
background: -moz-linear-gradient(top, #E4E3E3, #FFFFFF);
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#E4E3E3', endColorstr='#FFFFFF');
padding: 3px 4px 2px 4px;
margin: 2px;
text-decoration: none;
border: 1px solid #ccc;
color: #666;
}
ul.page-numbers a:hover,
ul.page-numbers span.current {
border: 1px solid #666;
color: #444;
}