Я пытаюсь отобразить функцию внутри функции Ajax с циклом foreach из списка пользователей!
Для ясности: у меня есть список подписчиков / подписчиков внутри author.php
, затем я создалAjax pagination для них с кнопкой loadmore.
Я использую плагин " Users Follow System ", ниже вы можете найти эту функцию для отображения ссылки следующей кнопки echo pwuf_get_follow_unfollow_links( $user->ID );
Я использовал это раньше с другим постраничным шаблоном, но не с Ajax и работал без проблем!
Но когда я пытаюсь добавить его в функцию Ajax, не работает, когда я нажимаю кнопку ( follow)) это прыгает в начало страницы?
Также попытался добавить #!на ссылку href="#!"
, страница перестала переходить наверх, но кнопка «Следить» не работает!
Консоль и отладка понятны!Так что я делаю не так?
Вот весь мой код, и я надеюсь выяснить, в чем дело,
Пожалуйста, скажите мне, если я пропущу добавить какой-либо другой код, Спасибо!
display-functions.php следующей кнопки.
function pwuf_get_follow_unfollow_links( $follow_id = null ) {
global $user_ID;
if( empty( $follow_id ) )
return;
if( ! is_user_logged_in() )
return;
if ( $follow_id == $user_ID )
return;
ob_start(); ?>
<div class="follow-links">
<?php
if ( pwuf_is_following( $user_ID, $follow_id ) ) {
$classes = "unfollow";
$text = "Following";
} else {
$classes = "follow";
$text = "Follow";
}
?>
<span><a href="#" class="<?php echo $classes; ?>" data-user-id="<?php echo $user_ID; ?>" data-follow-id="<?php echo $follow_id; ?>"><span><?php echo $text; ?></span></a></span>
<img src="<?php echo PWUF_FOLLOW_URL; ?>/images/loading.svg" class="pwuf-ajax" style="display:none;"/>
</div>
<?php
return ob_get_clean();
}
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'];
/// detect the author data with the name or with the author id
$curauth = NULL;
if( isset($_POST['author_name']) AND trim($_POST['author_name']) != '' ) {
$curauth = get_user_by('slug', trim($_POST['author_name']) );
} elseif( isset($_POST['author']) AND intval($_POST['author']) > 0 ) {
$curauth = get_userdata( intval($_POST['author']) );
}
if( !is_null($curauth) ) {
$include = get_user_meta($curauth->ID, '_pwuf_following', true);
if ( empty( $include ) ) {
echo '<div class="no-follower">Not found followers yet <i class="fa fa-slack fa-1x" aria-hidden="true"></i></div>';
} else {
$args = array (
'order' => 'DESC',
'include' => $include,
'number' => '20',
'paged' => $paged
);
$wp_user_query = new WP_User_Query( $args );
$users = $wp_user_query->get_results();
foreach ( $users as $user ) {
$avatar = get_avatar($user->user_email, 100);
$author_profile_url = get_author_posts_url($user->ID);
$profile = get_userdata($user->ID);
echo '<div class="members-name-9"><a href="', $author_profile_url, '">' . $profile->first_name .'</a>';
echo '<a href="', $author_profile_url, '">', $avatar , '</a>';
echo pwuf_get_follow_unfollow_links( $user->ID );
}
echo '</div>';
}
} else {
echo '<div class="no-follower">Not found followers yet <i class="fa fa-slack fa-1x" aria-hidden="true"></i></div>';
}
wp_die();
}
follow.js
jQuery(document).ready(function($) {
/*******************************
follow / unfollow a user
*******************************/
$( '.follow-links a' ).on('click', function(e) {
e.preventDefault();
var $this = $(this);
if( pwuf_vars.logged_in != 'undefined' && pwuf_vars.logged_in != 'true' ) {
alert( pwuf_vars.login_required );
return;
}
var data = {
action: $this.hasClass('follow') ? 'follow' : 'unfollow',
user_id: $this.data('user-id'),
follow_id: $this.data('follow-id'),
nonce: pwuf_vars.nonce
};
$this.closest('.follow-links').find('img.pwuf-ajax').show();
$.post( pwuf_vars.ajaxurl, data, function ( response ) {
if ( response == 'success' ) {
if ( $this.hasClass( 'follow' ) ) {;
$this.removeClass( 'follow' ).addClass( 'unfollow' );
$this.find( 'span' ).text( 'Unfollow' );
} else {;
$this.removeClass( 'unfollow' ).addClass( 'follow' );
$this.find( 'span' ).text( 'Follow' );
}
} else {
alert( pwuf_vars.processing_error );
}
$this.closest('.follow-links').find('img.pwuf-ajax').hide();
});
});
});