0

Bones テーマ ( http://themble.com/bones )で使用されているものに基づいて、Wordpress のページ ナビゲーション用のカスタム関数を使用しています。この関数は、番号付きのページ リンクを出力しますが、最初または最後のページにいる場合でも、前のページ ボタンと次のページ ボタンの両方を出力します。最初のページにいないときは前のページ ボタンのみを表示し、最後のページにいないときは次のページ ボタンのみを表示するように調整したいと考えています。うまくいけば、それは理にかなっています!

関数は次のとおりです。

function custom_page_navi($before = '', $after = '') {
global $wpdb, $wp_query;
$request = $wp_query->request;
$posts_per_page = intval(get_query_var('posts_per_page'));
$paged = intval(get_query_var('paged'));
$numposts = $wp_query->found_posts;
$max_page = $wp_query->max_num_pages;
if ( $numposts <= $posts_per_page ) { return; }
if(empty($paged) || $paged == 0) {
    $paged = 1;
}
$pages_to_show = 7;
$pages_to_show_minus_1 = $pages_to_show-1;
$half_page_start = floor($pages_to_show_minus_1/2);
$half_page_end = ceil($pages_to_show_minus_1/2);
$start_page = $paged - $half_page_start;
if($start_page <= 0) {
    $start_page = 1;
}
$end_page = $paged + $half_page_end;
if(($end_page - $start_page) != $pages_to_show_minus_1) {
    $end_page = $start_page + $pages_to_show_minus_1;
}
if($end_page > $max_page) {
    $start_page = $max_page - $pages_to_show_minus_1;
    $end_page = $max_page;
}
if($start_page <= 0) {
    $start_page = 1;
}
echo $before.'<nav class="pagination"><ol class="custom_page_navi">'."";
if ($start_page >= 2 && $pages_to_show < $max_page) {
    $first_page_text = __( "First");
    echo '<li class="cpn-first-page-link"><a href="'.get_pagenum_link().'" title="'.$first_page_text.'">'.$first_page_text.'</a></li>';
}
echo '<li class="cpn-prev-link">';
previous_posts_link('');
echo '</li>';
for($i = $start_page; $i  <= $end_page; $i++) {
    if($i == $paged) {
        echo '<li class="cpn-current">'.$i.'</li>';
    } else {
        echo '<li><a href="'.get_pagenum_link($i).'">'.$i.'</a></li>';
    }
}
echo '<li class="cpn-next-link">';
next_posts_link('');
echo '</li>';
if ($end_page < $max_page) {
    $last_page_text = __( "Last");
    echo '<li class="cpn-last-page-link"><a href="'.get_pagenum_link($max_page).'" title="'.$last_page_text.'">'.$last_page_text.'</a></li>';
}
echo '</ol></nav>'.$after."";

}

何か案は?

4

1 に答える 1

0

放置しないのはなぜですか?また、 Bones の公式 Gitも役立ちます。この質問でサポートの問題を開きます。とにかく、この未テストのコードを試してください:

これを変える:

if ($end_page < $max_page) {
    $last_page_text = __( "Last", 'bonestheme' );
    echo '<li class="bpn-last-page-link"><a href="'.get_pagenum_link($max_page).'" title="'.$last_page_text.'">'.$last_page_text.'</a></li>';
}

これに:

if ($end_page < $max_page && != $max_page) {
    $last_page_text = __( "Last", 'bonestheme' );
    echo '<li class="bpn-last-page-link"><a href="'.get_pagenum_link($max_page).'" title="'.$last_page_text.'">'.$last_page_text.'</a></li>';
    }
于 2013-08-06T18:02:40.160 に答える