jQuery AJAX调用未在Wordpress中返回结果

平野

我正在尝试在Wordpress应用中构建“加载更多”按钮,但是AJAX返回值始终为“成功:假”,即使我知道数据库中还有更多帖子。我遵循了在YouTube上找到的教程,但是不确定我缺少什么。

JS

jQuery(document).ready(function () {
  const button = document.getElementById('loadmore');
  button.addEventListener('click', () => {
    let current_page = document.querySelector('#main-content').dataset.page;
    // let max_pages = document.querySelector('#main-content').dataset.max;

    const params = {
      'action': 'load_more_posts',
      'current_page': current_page
    }

    $.post('/wp-admin/admin-ajax.php', params, (data) => {
      console.log(data);
    });
  });
})

PHP(functions.php)

wp_enqueue_script('loadmore', get_template_directory_uri() . '/js/loadmore.js', array('jquery'), filemtime(get_template_directory() . '/js/loadmore.js'));

add_action('wp_ajax_nopriv_load_more_posts', 'load_more_posts');
add_action('wp_ajax_load_more_posts', 'load_more_posts');
function load_more_posts() {
    $next_page = $_POST['current_page'] + 1;
    $query = new WP_Query([
        'posts_per_page' => 12,
        'paged' => $next_page
    ]);
    if ($query->has_posts()):
        ob_start();
    while($query->have_posts()) : $query->the_post();
        get_template_parts('partials/blog','posts');
    endwhile;
    wp_send_json_success(ob_get_clean());
    else:
        wp_send_json_error('no more posts');
    endif;
}

返回的结果仍然是:

data: "no more posts"
success: false
洛克希格

通常也让我感到一件事的是,即使其余代码正确,您的ajax函数也应始终以wp_die();函数调用结尾,否则它将始终返回0

在这种情况下:

function load_more_posts() {
    $next_page = $_POST['current_page'] + 1;
    $query = new WP_Query([
        'posts_per_page' => 12,
        'paged' => $next_page
    ]);
    if ($query->have_posts()):
        ob_start();
        while($query->have_posts()) : $query->the_post();
            get_template_parts('partials/blog','posts');
        endwhile;
        wp_send_json_success(ob_get_clean());
    else:
        wp_send_json_error('no more posts');
    endif;

    wp_die();

}

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章