2012-07-10 120 views
1

是否有人會知道爲什麼Wordpress Multisite的WP-PAGINATE插件在頁碼和上一個/下一個箭頭的鏈接中重複一個網站的主頁url?該頁面是不使用自定義帖子的默認帖子頁面。與插件的所有分頁鏈接正在生成404。我嘗試更新永久鏈接。WP-PAGINATE Wordpress分頁url 404錯誤

下面是它給URL的一個例子: http://www.site.com/a_site_name/a_site_name/page/2

它應該是: http://www.site.com/a_site_name/page/2

感謝。

回答

0

爲了解決這個問題,我做的事就是打開WP-包括/鏈接的template.php和註釋掉線1389具有以下替換它:

//$home_root = preg_quote(trailingslashit($home_root), '|'); 
$home_root = preg_quote($home_root, '|'); 

(使用的Wordpress版本是3.3.1)

2

我知道這篇文章有點老了......但是如果它有助於某人的幫助,那麼也很好。我嘗試使用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' => '&raquo;', 
    'prev_text' => '&laquo;' 
    ); 

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; 
}