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? */ ?>

Ajaxをお探しの場合は、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 2012

この@Pippinに感謝します。スタジオに着いたら試してみます。1つの質問:admin_urlの「your-page-path」の部分には何を入れますか?それは私のサイトのルートですか?
大須

ユーザーを表示しているページは、管理者またはフロントエンドにありますか?
ピピン

1
興味深いアプローチ。ここで2つのクエリを実行していることに気付きました。最初のクエリはすべてのユーザーを取得し、2番目のクエリは適切なページのユーザーのみを取得します。クエリを1つだけ使用し、次にarray_sliceを使用して結果をページに分割すると、パフォーマンスが向上しませんか?同じデータに対して2つの異なるクエリを実行しているため、1つを削除することでパフォーマンスをいくらか節約できるようです。
codescribblr 2015年

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ページから


2018年6月8日更新:次/前の代わりにページ番号を追加する方法

次/前のページリンクの代わりにページ番号が必要な場合は、次の方法で設定できます。番号をページリンクに置き換える必要があることに注意してください。この例ではクリックできません(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]

同意する。ピピンの答えは、可能であれば避けるべきであるdbで2ヒットを必要とします。
の相撲

1
こんにちは@ radley-sustaireです。これは素晴らしい解決策ですが、「6人中2人のユーザーを表示する」部分をページあたりの実際のユーザー範囲に変更する方法があるかどうか疑問に思いました。つまり、1ページ目は「1-2 of 6を表示」、2ページ目は「3-4 of 6」、3ページ目は「5-6 of 6」のように表示されます。現時点では、「2 of 6」と表示されます。すべてのページ。
damienoneill2001 2018

1
:良いアイデアだdamienoneill2001 @、あなたのような何かを始めることができる$start_user_num = (($current_page-1) * $users_per_page) + 1;$end_user_num = $start_user_num + count($users->get_results());
Radley Sustaire、2018

@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に、私のソリューションでは正しくない数字が表示されます。設計図に戻って、ha!
damienoneill2001 2018

1

完全なクレジットは彼の答えを@ radley-sustaireに送るべきですが、私はそれで小さな不具合を見つけたので、ここで自分のバージョンの答えを共有します。

私のバージョンでは、場所やキーワードなどで結果をフィルタリングしていたため、一部のページでは「$ users_per_page」変数よりも結果が少なくなりました。たとえば、ページあたりのユーザー数が10に設定されていても、フィルターの結果が3人のユーザーしか返さなかった場合、ページの上部に「Displaying 10 of 3 users」が表示されます。明らかにこれは意味をなさなかったので、結果の数が '$ users_per_page'変数よりも高いかどうかを確認する単純な「if」ステートメントを追加しました。

ラドリー、更新であなたの回答を編集した場合、ピピンのソリューションよりも優れていると思うので、私は喜んで正解として投票します。

だから、これはそれを望む誰にとっても最終的なコードです。

<?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>
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.