2013-08-06 62 views
0

我正在使用Wordpress中的頁面導航自定義功能,該功能基於Bones主題(http://themble.com/bones)中使用的功能。該功能輸出帶編號的頁面鏈接,但也會輸出上一頁和下一頁按鈕,即使您在第一頁或最後一頁上也是如此。我想調整它,只在不在第一頁時顯示上一頁按鈕,並且當您不在最後一頁時只顯示下一頁按鈕。希望這是有道理的!如何從分頁功能中刪除上一個/下一個按鈕?

這裏的功能:

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.""; 

}

任何想法?

回答

0

爲什麼不把它留下呢?另外Bones official 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>'; 
    } 
+0

感謝。如果僅顯示相關按鈕,則可用性會更好,因爲另一個按鈕在不活動時不會執行任何操作。試過這段代碼,不幸的是它出現了一個服務器錯誤。 – jasonbradberry

+0

我已經更新了我的答案。嘗試官方Bones Github頁面。 – BenRacicot

+0

感謝您的幫助 - 仍然有服務器錯誤,所以會嘗試Bones Github頁面。 – jasonbradberry

相關問題