Wordpress-使用Ajax的关注用户列表

时间:2018-09-24 06:14:58

标签: php ajax wordpress author

我正在使用“ Users Following System”插件。到目前为止,我已经在author.php配置文件中添加了以下/关注者列表,现在我正试图与此一起使用Ajax,但是面临的问题是,我需要为每个用户获取相同的用户元ID,这样每个人都可以看到以下彼此的用户。

author.php中,我使用此行来获取用户信息。

<?php
    $curauth = (isset($_GET['author_name'])) ? get_user_by('slug', $author_name) : get_userdata(intval($author));
?>

此行用于获取_pwuf_following的用户元信息

$include = get_user_meta($curauth->ID, '_pwuf_following', true);

但是当我在Ajax函数处理程序中添加相同的行时不起作用。

我尝试了get_queried_object(); wp_get_current_user(); get_userdata();
但我总是失败。

这是author.php中的片段,用于获取以下用户的列表。

<?php

$curauth = (isset($_GET['author_name'])) ? get_user_by('slug', $author_name) : get_userdata(intval($author));

$include = get_user_meta($curauth->ID, '_pwuf_following', true);

if ( empty( $include ) ) {

     echo 'Not followed anyone yet.';

    } else {

$args = array (
    'order' => 'DESC',
    'include'  => $include,
    'number'  => 52,
    'paged' => 1
);

$wp_user_query = new WP_User_Query( $args );

$users = $wp_user_query->get_results();

    echo '<div id="top-artists-contributors-3">';
    echo '<ul id="grid-contributors-4">';
    echo '<li class="scroll-artists">';
    foreach ( $users as $user ) {
        $avatar_size = 90;
        $avatar = get_avatar($user->user_email, 200);
        $author_profile_url = get_author_posts_url($user->ID);
        $profile = get_userdata($user->ID);

    echo '<div class="single-item-3">';
    echo '<div class="author-gravatar-3"><a href="', $author_profile_url, '">', $avatar , '</a></div>';
    echo '<div class="members-name"><a href="', $author_profile_url, '">' . $profile->first_name .'</a></div>';
    echo '</div>';           
    }
    echo '</li>';
    echo '</ul>';
    echo '</div>';
}
?>

这是获取Ajax网址和操作的js

<script type="text/javascript">
var ajaxurl = "<?php echo admin_url( 'admin-ajax.php' ); ?>";
var page = 2;
var canBeLoaded = true,
bottomOffset = 2000;

jQuery(function($) {
$(window).scroll(function() {
    if( $(document).scrollTop() > ( $(document).height() - bottomOffset ) && canBeLoaded == true ) {
    canBeLoaded = false;
        var data = {
            'action': 'user_following_by_ajax',
            'page': page,
            'security': '<?php echo wp_create_nonce("user_more_following"); ?>'
        };
        $.post(ajaxurl, data, function(response) {
            $('#following').append(response);
            canBeLoaded = true;
            page++;
        });
    }
});
});
</script>

这是来自Ajax处理程序的function.php。

add_action('wp_ajax_user_following_by_ajax', 'user_following_by_ajax_callback');
add_action('wp_ajax_nopriv_user_following_by_ajax', 'user_following_by_ajax_callback');

function user_following_by_ajax_callback() {
    check_ajax_referer('user_more_following', 'security');
    $paged = $_POST['page'];

$curauth = (isset($_GET['author_name'])) ? get_user_by('slug', $author_name) : get_userdata(intval($author));

$include = get_user_meta($curauth->ID, '_pwuf_following', true);


if ( empty( $include ) ) {

     echo 'Not followed anyone yet.';

    } else {

$args = array (
    'order' => 'DESC',
    'include'  => $include,
    'number'  => 52,
    'paged' => $paged
);

$wp_user_query = new WP_User_Query( $args );

$users = $wp_user_query->get_results();

    echo '<div id="top-artists-contributors-3">';
    echo '<ul id="grid-contributors-4">';
    echo '<li class="scroll-artists">';
    foreach ( $users as $user ) {
        $avatar_size = 90;
        $avatar = get_avatar($user->user_email, 200);
        $author_profile_url = get_author_posts_url($user->ID);
        $profile = get_userdata($user->ID);

    echo '<div class="single-item-3">';
    echo '<div class="author-gravatar-3"><a href="', $author_profile_url, '">', $avatar , '</a></div>';
    echo '<div class="members-name"><a href="', $author_profile_url, '">' . $profile->first_name .'</a></div>';
    echo '</div>';           
    }
    echo '</li>';
    echo '</ul>';
    echo '</div>';
    }
    wp_die();
}

1 个答案:

答案 0 :(得分:1)

我可以看到您没有传递代码中使用的author_name字段。请检查下面的代码,其中我已添加缺少的字段。

           <script type="text/javascript">
            var ajaxurl = "<?php echo admin_url( 'admin-ajax.php' ); ?>";
            var page = 2;
            var canBeLoaded = true,
            bottomOffset = 2000;


            jQuery(function($) {
            $(window).scroll(function() {
                if( $(document).scrollTop() > ( $(document).height() - bottomOffset ) && canBeLoaded == true ) {
                canBeLoaded = false;
                    var data = {
                        'action': 'user_following_by_ajax',
                        'data': { page : 'page', author_name: '<?php echo get_the_author(); ?>' }, // Here set author name which you are getting.
                        'security': '<?php echo wp_create_nonce("user_more_following"); ?>'
                    };
                    $.post(ajaxurl, data, function(response) {
                        $('#following').append(response);
                        canBeLoaded = true;
                        page++;
                    });
                }
            });
            });
            </script>