0

У меня есть настраиваемый шаблон страницы, и я нашел фрагмент PHP, который создает разбиение на страницы в таблице html. Но код работает неправильно.Pagination не работает должным образом с использованием PHP в Wordpress

ОБНОВЛЕНИЕ: Я меняю код. Но все же код работает некорректно, когда я нажимаю на вторую страницу, на второй странице отображается только пустая страница.

Как это исправить?

if (isset($_POST['list_position']) && $_POST['list_position'] != 'Select by Position'){ 
    $list_position= $_POST['list_position']; 
    $result_position= $wpdb->get_results($wpdb->prepare("SELECT DISTINCT id, submit_time, last_name, first_name, middle_name, mobile_number, email, location, position, message, attachment_resume_id FROM resume_databank WHERE position= '" . $list_position . "' ORDER BY position ASC", OBJECT)); 

$rows_per_page = 3; 
$current = (intval(get_query_var('paged'))) ? intval(get_query_var('paged')) : 1; 

global $wp_rewrite; 

$pagination_args = array(
    'base' => @add_query_arg('paged','%#%'), 
    'format' => '', 
    'total' => ceil(sizeof($result_position)/$rows_per_page), 
    'current' => $current, 
    'show_all' => false, 
    'type' => 'plain', 
); 

if($wp_rewrite->using_permalinks()) 
    $pagination_args['base'] = user_trailingslashit(trailingslashit(remove_query_arg('s',get_pagenum_link(1))) . 'page/%#%/', 'paged'); 

if(!empty($wp_query->query_vars['s'])) 
    $pagination_args['add_args'] = array('s'=>get_query_var('s')); 
    echo paginate_links($pagination_args); 

$start = ($current - 1) * $rows_per_page; 
$end = $start + $rows_per_page; 
$end = (sizeof($result_position) < $end) ? sizeof($result_position) : $end; 

    echo '<table id="paginate_result">'; 
     echo '<tr>'; 
     $optionId = 0; 
     echo '<th>Submit Time</th>'; 
     echo '<th>Last Name</th>'; 
     echo '<th>First Name</th>'; 
     echo '<th>Middle Name</th>'; 
     echo '<th>Mobile Number</th>'; 
     echo '<th>Email</th>'; 
     echo '<th>Location</th>'; 
     echo '<th>Position</th>'; 
     echo '<th>Message</th>'; 
     echo '<th>Resume</th>'; 
     echo '<th>Processed?</th>'; 
     //foreach ($result_position as $record_s){ 
      for ($i=$start;$i < $end ;++$i) { 
      $row = $result_position[$i]; 
      $optionId++; 
      echo '<tr>'; 
      echo '<td id="submit_time">' . $result_position[0]->submit_time . '</td>'; 
      echo '<td id="last_name">' . $result_position[0]->last_name . '</td>'; 
      echo '<td id="first_name">' . $result_position[0]->first_name . '</td>'; 
      echo '<td id="middle_name">' . $result_position[0]->middle_name . '</td>'; 
      echo '<td id="mobile_number">' . $result_position[0]->mobile_number . '</td>'; 
      echo '<td id="email">' . $result_position[0]->email . '</td>'; 
      echo '<td id="location">' . $result_position[0]->location . '</td>'; 
      echo '<td id="position">' . $result_position[0]->position . '</td>'; 
      echo '<td id="message">' . $result_position[0]->message . '</td>'; 
      echo '<td id="resumeFile'.$optionId.'"><a href=' . wp_get_attachment_url($result_position[0]->attachment_resume_id) . '>Download Resume</a></td>'; 
      echo '<td id="radioOption><label for="Yes">Yes</label> 
         <input type="radio" id="processedOptionYes'.$optionId.'" name="processedOption" value="Yes" onclick="proccessedCheck('.$optionId.',\'Yes\')"/> 
         <label for="No">No</label> 
         <input type="radio" id="processedOptionNo'.$optionId.'" name="processedOption" value="No" onclick="proccessedCheck('.$optionId.',\'No\')"/></td>'; 
      echo '</tr>'; 
     } 
     echo '</table>'; 
+0

должен быть .. '$ total_query =" SE LECT COUNT (*) FROM ({$ query}) AS mixed_table ";' –

+0

еще одна проблема :( – User014019

+0

должно быть '' ORDER BY поле ASC LIMIT {$ offset}, {$ items_per_page} "' –

ответ

0

См Эта связь

http://www.rvoodoo.com/blog/wordpress-tip-fixing-pagination-on-custom-queries-with-query_posts/

content.php до этой линии

<?php if (have_posts()) : ?> 

вставьте этот контент

<?php query_posts(array(
    'cat' => '-20', 
    'paged' => (get_query_var('paged') ? get_query_var('paged') : 1), 
));?> 
+0

Я не использую существующий файл wordpress. Я использую настраиваемый шаблон страницы – User014019

Смежные вопросы