私は同じ問題を抱えていましたが、これですべてが解決しました。これにより、かなりのパーマリンクを使用して、index.php と page.php のページネーションを行うことができます。
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('post', 'music', 'videos'), 'orderby'=>'date', 'order'=>'DESC', 'posts_per_page' => 10, 'paged' => $paged);
$wp_query = new WP_Query();
$wp_query->query( $args );
while ($wp_query->have_posts()) : $wp_query->the_post();
?>
<!--your loop stuff here -->
<?php endwhile; ?>
<nav>
<?php paginate(); ?>
$wp_query = null;
$wp_query = $temp; // Reset
</nav>
これにより、いくつかのことが可能になります。1 つは、ホーム、ページ、またはシングルのいずれであるかをチェックし、$paged 変数に順番にどのように反応するかを指示します。カスタム投稿タイプでページネーションをクエリすることもできます。また、query_post を使用しないことで、使用時に発生する非常にファンキーなものを避けることができます。paginate(); は、現在導入しているカスタム関数です。
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() )
$pagination['base'] = user_trailingslashit( trailingslashit( remove_query_arg( 'page', 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を書き換えてきれいなパーマリンクを許可します。リンクを確認すると、変数「s」が「paged」の代わりに使用されていました。「s」を「paged」に置き換えたところ、すべてが完全に機能しました。
ページネーションのオプションのスタイリング
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;
}
編集
後、ページ タブの 1 つをクリックすると、ホームページのページネーションが壊れることに気付きました。条件ステートメントを置き換えて、これをその場所に配置することで、これを修正しました。上記のコードも更新しました。
$pagination['base'] = user_trailingslashit( trailingslashit( remove_query_arg( 'page', get_pagenum_link( 1 ) ) ) . '?page=%#%/', 'paged' );