Як відобразити посилання на сторінки для WP_User_Query?


10

Я думаю, що я майже зіткнувся з цим, але я не можу отримати посилання на сторінки, щоб показати каталог авторів, який я створюю.

Мій код нижче, але я не знаю, як змусити посилання переходити між сторінками авторів для роботи. Хтось може мені допомогти? У мене є відчуття, що це може бути корисним, але я не знаю, як це здійснити:

paginate_links ()

Дякую

Осу

    <?php 
/* ****************************************************************** */
                        /* !LIST AUTHORS */
/* ****************************************************************** */ 

// THANKS TO:
// http://www.mattvarone.com/wordpress/list-users-with-wp_user_query/

// pagination
$paged = (get_query_var('paged')) ? get_query_var('paged') : 1; // Needed for pagination
$paged -= 1;
$limit = 2;
$offset = $paged * $limit;

// prepare arguments
$args  = array(
    // search only for Authors role
    'role'      => 'Subscriber',
    // order results by display_name
    'orderby'   => 'display_name',
    // return all fields
    'fields'    => 'all_with_meta',
    'number'    => $limit,
    'offset'    => $offset      
);
// Create the WP_User_Query object
$wp_user_query = new WP_User_Query($args);
// Get the results
$authors = $wp_user_query->get_results();
// Check for results
if (!empty($authors))
{
    echo '<div class="author-entry">';
    // loop trough each author
    foreach ($authors as $author)
    {
        $author_info = get_userdata($author->ID); ?>

        <span style="float:left;padding:0 5px 0 0;"><?php echo get_avatar( $author->ID, 50 ); /* http://codex.wordpress.org/Function_Reference/get_avatar */ ?></span>
        <span class="fn"><strong>First name</strong> : <?php echo $author_info->first_name; ?></span><br />
        <span class="ln"><strong>Last name</strong> : <?php echo $author_info->last_name; ?></span><br />
        <span class="em"><strong>Email address</strong> : <a href="mailto:<?php echo $author_info->user_email; ?>"><?php echo $author_info->user_email; ?></a></span><br />
        <span class="we"><strong>Website</strong> : <a href="<?php echo $author_info->user_url; ?>"><?php echo $author_info->user_url; ?></a></span><br />

        <span class="de"><strong>Bio</strong> :<br /><?php echo $author_info->description ; ?></span>
        <div class="clear">&nbsp;</div>

    <?php 
    }
    echo '</div>';
} else {
    echo 'No authors found';
}
?>

<?php /* WHAT DO I PUT HERE TO CREATE THE PAGINATION LINKS? */ ?>

якщо ви шукаєте Аякс, тоді завітайте сюди wordpress.stackexchange.com/questions/113379/…
Сабір Абдул Гафур Шайх

Відповіді:


17

Це повинно вас зблизити. Я не перевіряв його, але він майже ідентичний установці, яку я використовував кілька разів.

/*
 * We start by doing a query to retrieve all users
 * We need a total user count so that we can calculate how many pages there are
 */

$count_args  = array(
    'role'      => 'Subscriber',
    'fields'    => 'all_with_meta',
    'number'    => 999999      
);
$user_count_query = new WP_User_Query($count_args);
$user_count = $user_count_query->get_results();

// count the number of users found in the query
$total_users = $user_count ? count($user_count) : 1;

// grab the current page number and set to 1 if no page number is set
$page = isset($_GET['p']) ? $_GET['p'] : 1;

// how many users to show per page
$users_per_page = 5;

// calculate the total number of pages.
$total_pages = 1;
$offset = $users_per_page * ($page - 1);
$total_pages = ceil($total_users / $users_per_page);


// main user query
$args  = array(
    // search only for Authors role
    'role'      => 'Subscriber',
    // order results by display_name
    'orderby'   => 'display_name',
    // return all fields
    'fields'    => 'all_with_meta',
    'number'    => $users_per_page,
    'offset'    => $offset // skip the number of users that we have per page  
);

// Create the WP_User_Query object
$wp_user_query = new WP_User_Query($args);

// Get the results
$authors = $wp_user_query->get_results();

// check to see if we have users
if (!empty($authors))
{
    echo '<div class="author-entry">';
    // loop trough each author
    foreach ($authors as $author)
    {
        $author_info = get_userdata($author->ID); ?>

        <span style="float:left;padding:0 5px 0 0;"><?php echo get_avatar( $author->ID, 50 ); /* http://codex.wordpress.org/Function_Reference/get_avatar */ ?></span>
        <span class="fn"><strong>First name</strong> : <?php echo $author_info->first_name; ?></span><br />
        <span class="ln"><strong>Last name</strong> : <?php echo $author_info->last_name; ?></span><br />
        <span class="em"><strong>Email address</strong> : <a href="mailto:<?php echo $author_info->user_email; ?>"><?php echo $author_info->user_email; ?></a></span><br />
        <span class="we"><strong>Website</strong> : <a href="<?php echo $author_info->user_url; ?>"><?php echo $author_info->user_url; ?></a></span><br />

        <span class="de"><strong>Bio</strong> :<br /><?php echo $author_info->description ; ?></span>
        <div class="clear">&nbsp;</div>

    <?php 
    }
    echo '</div>';
} else {
    echo 'No authors found';
}

// grab the current query parameters
$query_string = $_SERVER['QUERY_STRING'];

// The $base variable stores the complete URL to our page, including the current page arg

// if in the admin, your base should be the admin URL + your page
$base = admin_url('your-page-path') . '?' . remove_query_arg('p', $query_string) . '%_%';

// if on the front end, your base is the current page
//$base = get_permalink( get_the_ID() ) . '?' . remove_query_arg('p', $query_string) . '%_%';

echo paginate_links( array(
    'base' => $base, // the base URL, including query arg
    'format' => '&p=%#%', // this defines the query parameter that will be used, in this case "p"
    'prev_text' => __('&laquo; Previous'), // text for previous page
    'next_text' => __('Next &raquo;'), // text for next page
    'total' => $total_pages, // the total number of pages we have
    'current' => $page, // the current page
    'end_size' => 1,
    'mid_size' => 5,
));

2
+1 Був би задоволений, якщо код розбити і пояснити :)
kaiser

5
Там додали кілька кращих коментарів та виправили помилку чи дві :)
Pippin

Дякую за це @Pippin, я спробую це, коли потрапляю в студію. Одне запитання: що я можу поставити у частині "your-page-path" в адміністраторі_url? Це корінь мого сайту?
Осу,

Сторінка, на якій відображаються ваші користувачі в адміністраторі або на передній частині?
Піппін

1
Цікавий підхід. Я помітив, що ви проводите 2 запити: перший отримує всіх користувачів, а другий - лише користувачі на відповідній сторінці. Чи не буде це краще, якщо ви використовували лише 1 запит, а потім використовували array_slice, щоб розділити результати на сторінки? Здається, оскільки ви виконуєте два різних запити на одних і тих же даних, ви можете зберегти деяку ефективність, скинувши один.
codecribblr

11

Ви дійсно не повинні використовувати відповідь Піппіна. Запит дуже неефективний. $user_count_queryу прикладі можна повернути до Вашого сценарію до 999 999 користувачів із Вашої бази даних із усіма полями користувача. Це, безсумнівно, вплине на пам'ять та / або обмеження часу для PHP, якщо / коли ваш сайт зростає досить великим.

Але це, можливо, було єдиним рішенням ще у 2012 році.

Ось кращий спосіб зробити це. У цьому прикладі я отримав лише наступну та попередню сторінку, але якщо вам потрібна нумерована сторінка, змінні існують для її створення. У WordPress немає функції пагинації, сумісної з WP_User_Query (наскільки мені відомо).

<?php

// Pagination vars
$current_page = get_query_var('paged') ? (int) get_query_var('paged') : 1;
$users_per_page = 2; // RAISE THIS AFTER TESTING ;)

$args = array(
    'number' => $users_per_page, // How many per page
    'paged' => $current_page // What page to get, starting from 1.
);

$users = new WP_User_Query( $args );

$total_users = $users->get_total(); // How many users we have in total (beyond the current page)
$num_pages = ceil($total_users / $users_per_page); // How many pages of users we will need

?>
    <h3>Page <?php echo $current_page; ?> of <?php echo $num_pages; ?></h3>
    <p>Displaying <?php echo $users_per_page; ?> of <?php echo $total_users; ?> users</p>

    <table>
        <thead>
            <tr>
                <th>First Name</th>
                <th>Last Name</th>
                <th>Email</th>
            </tr>
        </thead>

        <tbody>
            <?php
            if ( $users->get_results() ) foreach( $users->get_results() as $user )  {
                $firstname = $user->first_name;
                $lastname = $user->last_name;
                $email = $user->user_email;
                ?>
                <tr>
                    <td><?php echo esc_html($firstname); ?></td>
                    <td><?php echo esc_html($lastname); ?></td>
                    <td><?php echo esc_html($email); ?></td>
                </tr>
                <?php
            }
            ?>
        </tbody>
    </table>

    <p>
        <?php
        // Previous page
        if ( $current_page > 1 ) {
            echo '<a href="'. add_query_arg(array('paged' => $current_page-1)) .'">Previous Page</a>';
        }

        // Next page
        if ( $current_page < $num_pages ) {
            echo '<a href="'. add_query_arg(array('paged' => $current_page+1)) .'">Next Page</a>';
        }
        ?>
    </p>

Приклад, що показує сторінку 2:

таблиця користувачів, починаючи з 2 сторінки


Оновлення 8.06.2018: Як додати номери сторінок замість наступного / попереднього

Якщо ви хочете мати номери сторінок замість наступних / попередніх посилань на сторінку, ось як їх налаштувати. Зауважте, що вам потрібно буде замінити номери на посилання на сторінку, їх не можна буде натискати в цьому прикладі (на основі https://stackoverflow.com/a/11274294/470480 , модифікованого для показу постійної кількості середніх чисел і не додавання "...", якщо сторінка насправді не пропущена).

Ви також можете побачити мій файл суті, який містить функцію багаторазового використання для цієї мети.

$current_page = 5; // Example
$num_pages = 10; // Example

$edge_number_count = 2; // Change this, optional

$start_number = $current_page - $edge_number_count;
$end_number = $current_page + $edge_number_count;

// Minus one so that we don't split the start number unnecessarily, eg: "1 ... 2 3" should start as "1 2 3"
if ( ($start_number - 1) < 1 ) {
    $start_number = 1;
    $end_number = min($num_pages, $start_number + ($edge_number_count*2));
}

// Add one so that we don't split the end number unnecessarily, eg: "8 9 ... 10" should stay as "8 9 10"
if ( ($end_number + 1) > $num_pages ) {
    $end_number = $num_pages;
    $start_number = max(1, $num_pages - ($edge_number_count*2));
}

if ($start_number > 1) echo " 1 ... ";

for($i=$start_number; $i<=$end_number; $i++) {
    if ( $i === $current_page ) echo " [{$i}] ";
    else echo " {$i} ";
}

if ($end_number < $num_pages) echo " ... {$num_pages} ";

Вихід (від сторінки 1 до 10):

[1]  2  3  4  5  ... 10 
1  [2]  3  4  5  ... 10 
1  2  [3]  4  5  ... 10 
1  2  3  [4]  5  ... 10 

1 ...  3  4  [5]  6  7  ... 10 
1 ...  4  5  [6]  7  8  ... 10 

1 ...  6  [7]  8  9  10
1 ...  6  7  [8]  9  10
1 ...  6  7  8  [9]  10
1 ...  6  7  8  9  [10]

Я згоден. Відповідь Піппіна вимагає 2 ударів на db, яких слід уникати, якщо це можливо.
Сумо

1
Привіт @ radley-sustaire, це чудове рішення, але мені було цікаво, чи є спосіб змінити частину "відображення 2 з 6 користувачів" на реальне коло користувачів на сторінці. Тож на кшталт "відображення 1-2 з 6" для сторінки 1, "3-4 з 6" для сторінки 2 та "5-6 з 6" для сторінки 3. На даний момент це просто показує "2 з 6" для всі сторінки.
damienoneill2001

1
@ damienoneill2001 Це гарна ідея, ви можете почати з чогось типу: $start_user_num = (($current_page-1) * $users_per_page) + 1;і $end_user_num = $start_user_num + count($users->get_results());.
Radley Sustaire

@RadleySustaire відмінно, дякую за це. Під - перше, я отримав наступну помилку: Call to a member function get_results() on a non-objectтак що я з поправками $end_user_numberдо $start_user_num + ($users_per_page-1);і вирішити цю проблему. Знову дякую!
damienoneill2001

Виявляється, я з цим незабаром поговорив. Коли я потрапляю на остаточну сторінку, яка не містить повного списку користувачів, явно показує неправильну цифру для $end_user_numberмого рішення. Назад до дошки для малювання, га!
damienoneill2001

1

Повна заслуга повинна відповідати @ radley-sustaire за його відповідь, але я помітив невеликий збій з цим, тому я ділюсь тут своєю версією відповіді.

З моєю версією я також фільтрував результати за місцеположенням, ключовими словами тощо, тому деякі сторінки мали менше результатів, ніж вар '$ users_per_page'. Так, наприклад, якщо моїм користувачам на кожній сторінці було встановлено показ 10, але результати фільтра повернули лише 3 користувачів, я отримав "Відображення 10 з 3 користувачів" у верхній частині сторінки. Очевидно, це не мало сенсу, тому я додав просту заяву "якщо", щоб перевірити, чи підрахунок результатів був більшим за змінну "$ users_per_page".

Радлі, якщо ви відредагуєте свою відповідь оновленням, я з радістю проголосую за правильну відповідь, оскільки я вважаю, що це краще, ніж рішення Піппіна.

Отже, це остаточний код для всіх, хто цього хоче.

<?php

// Pagination vars
$current_page = get_query_var('paged') ? (int) get_query_var('paged') : 1;
$users_per_page = 10;

$args = array(
    'number' => $users_per_page, // How many per page
    'paged' => $current_page // What page to get, starting from 1.
);

$users = new WP_User_Query( $args );

$total_users = $users->get_total(); // How many users we have in total (beyond the current page)
$num_pages = ceil($total_users / $users_per_page); // How many pages of users we will need

if ($total_users < $users_per_page) {$users_per_page = $total_users;}

?>
    <h3>Page <?php echo $current_page; ?> of <?php echo $num_pages; ?></h3>
    <p>Displaying <?php echo $users_per_page; ?> of <?php echo $total_users; ?> users</p>

    <table>
        <thead>
            <tr>
                <th>First Name</th>
                <th>Last Name</th>
                <th>Email</th>
            </tr>
        </thead>

        <tbody>
            <?php
            if ( $users->get_results() ) foreach( $users->get_results() as $user )  {
                $firstname = $user->first_name;
                $lastname = $user->last_name;
                $email = $user->user_email;
                ?>
                <tr>
                    <td><?php echo esc_html($firstname); ?></td>
                    <td><?php echo esc_html($lastname); ?></td>
                    <td><?php echo esc_html($email); ?></td>
                </tr>
                <?php
            }
            ?>
        </tbody>
    </table>

    <p>
        <?php
        // Previous page
        if ( $current_page > 1 ) {
            echo '<a href="'. add_query_arg(array('paged' => $current_page-1)) .'">Previous Page</a>';
        }

        // Next page
        if ( $current_page < $num_pages ) {
            echo '<a href="'. add_query_arg(array('paged' => $current_page+1)) .'">Next Page</a>';
        }
        ?>
    </p>
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.