在 WordPress 中加载更多帖子 Ajax 按钮

IT技术 javascript php jquery ajax wordpress
2021-02-10 10:04:20

我浏览了旧问题并尝试了许多不同的方法,似乎可以做到这一点。我最接近的工作是这里的这个:How to implement pagination on a custom WP_Query Ajax

我已经尝试了一切,但它不起作用。页面上绝对没有任何变化。如果检查负载更多按钮,单击它,在jQuery是使得负载更多按钮动作,因为它从改变<a id="more_posts">Load More</a><a id="more_posts" disables="disabled">Load More</a>其中甚至doesn6't似乎正确的,我反正。这不是添加帖子,我想我错过了一些简单的东西,但对于我的生活,我无法解决。

我的模板文件中的代码是:

<div id="ajax-posts" class="row">
    <?php 
    $postsPerPage = 3;
    $args = [
        'post_type' => 'post',
        'posts_per_page' => $postsPerPage,
        'cat' => 1
    ];

    $loop = new WP_Query($args);

    while ($loop->have_posts()) : $loop->the_post(); ?>
        <div class="small-12 large-4 columns">
            <h1><?php the_title(); ?></h1>
            <p><?php the_content(); ?></p>
        </div>
        <?php
    endwhile; 

    echo '<a id="more_posts">Load More</a>';
    
    wp_reset_postdata(); 
    ?>
</div>

我的函数文件中的代码是:

function more_post_ajax(){
    $offset = $_POST["offset"];
    $ppp = $_POST["ppp"];

    header("Content-Type: text/html");
    $args = [
        'suppress_filters' => true,
        'post_type' => 'post',
        'posts_per_page' => $ppp,
        'cat' => 1,
        'offset' => $offset,
    ];

    $loop = new WP_Query($args);

    while ($loop->have_posts()) { $loop->the_post(); 
        the_content();
    }
    exit; 
}

add_action('wp_ajax_nopriv_more_post_ajax', 'more_post_ajax'); 
add_action('wp_ajax_more_post_ajax', 'more_post_ajax');

我在页脚中的 jQuery 是:

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js"></script>
<script type="text/javascript">
    jQuery(document).ready( function($) {
        var ajaxUrl = "<?php echo admin_url('admin-ajax.php')?>";
        
        // What page we are on.
        var page = 5; 
        // Post per page
        var ppp = 3; 

        $("#more_posts").on("click", function() {
            // When btn is pressed.
            $("#more_posts").attr("disabled",true);

            // Disable the button, temp.
            $.post(ajaxUrl, {
                action: "more_post_ajax",
                offset: (page * ppp) + 1,
                ppp: ppp
            })
            .success(function(posts) {
                page++;
                $("#ajax-posts").append(posts);
                // CHANGE THIS!
                $("#more_posts").attr("disabled", false);
            });
        });
    });
</script>

任何人都可以看到我遗漏的东西或能够提供帮助吗?

2个回答

更新 24.04.2016。

我在我的页面https://madebydenis.com/ajax-load-posts-on-wordpress/上创建了关于在 26 主题上实现这个的教程,所以请随时查看:)

编辑

我已经在 25 号上测试过它并且它正在工作,所以它应该对你有用。

index.php 中(假设您想在主页面上显示帖子,但即使您将其放在页面模板中也应该可以工作)我放置:

    <div id="ajax-posts" class="row">
        <?php
            $postsPerPage = 3;
            $args = array(
                    'post_type' => 'post',
                    'posts_per_page' => $postsPerPage,
                    'cat' => 8
            );

            $loop = new WP_Query($args);

            while ($loop->have_posts()) : $loop->the_post();
        ?>

         <div class="small-12 large-4 columns">
                <h1><?php the_title(); ?></h1>
                <p><?php the_content(); ?></p>
         </div>

         <?php
                endwhile;
        wp_reset_postdata();
         ?>
    </div>
    <div id="more_posts">Load More</div>

这将输出类别 8 中的 3 个帖子(我在该类别中有帖子,所以我使用了它,你可以使用任何你想要的)。您甚至可以查询您所在的类别

$cat_id = get_query_var('cat');

这将为您提供在查询中使用的类别 ID。你可以把它放在你的加载器中(加载更多的div),然后用jQuery来拉

<div id="more_posts" data-category="<?php echo $cat_id; ?>">>Load More</div>

并拉出类别

var cat = $('#more_posts').data('category');

但现在,你可以忽略这一点。

接下来在functions.php中我添加了

wp_localize_script( 'twentyfifteen-script', 'ajax_posts', array(
    'ajaxurl' => admin_url( 'admin-ajax.php' ),
    'noposts' => __('No older posts found', 'twentyfifteen'),
));

在现有wp_localize_script. 这将加载 WordPress 自己的 admin-ajax.php,以便我们在 ajax 调用中调用它时可以使用它。

在functions.php 文件的末尾,我添加了将加载您的帖子的函数:

function more_post_ajax(){

    $ppp = (isset($_POST["ppp"])) ? $_POST["ppp"] : 3;
    $page = (isset($_POST['pageNumber'])) ? $_POST['pageNumber'] : 0;

    header("Content-Type: text/html");

    $args = array(
        'suppress_filters' => true,
        'post_type' => 'post',
        'posts_per_page' => $ppp,
        'cat' => 8,
        'paged'    => $page,
    );

    $loop = new WP_Query($args);

    $out = '';

    if ($loop -> have_posts()) :  while ($loop -> have_posts()) : $loop -> the_post();
        $out .= '<div class="small-12 large-4 columns">
                <h1>'.get_the_title().'</h1>
                <p>'.get_the_content().'</p>
         </div>';

    endwhile;
    endif;
    wp_reset_postdata();
    die($out);
}

add_action('wp_ajax_nopriv_more_post_ajax', 'more_post_ajax');
add_action('wp_ajax_more_post_ajax', 'more_post_ajax');

在这里,我在数组中添加了分页键,以便循环可以在您加载帖子时跟踪您所在的页面。

如果您已在加载程序中添加了类别,则应添加:

$cat = (isset($_POST['cat'])) ? $_POST['cat'] : '';

而不是 8,你会放$cat. 这将在$_POST数组中,您将能够在 ajax 中使用它。

最后一部分是ajax本身。functions.js中我放入了$(document).ready();环境

var ppp = 3; // Post per page
var cat = 8;
var pageNumber = 1;


function load_posts(){
    pageNumber++;
    var str = '&cat=' + cat + '&pageNumber=' + pageNumber + '&ppp=' + ppp + '&action=more_post_ajax';
    $.ajax({
        type: "POST",
        dataType: "html",
        url: ajax_posts.ajaxurl,
        data: str,
        success: function(data){
            var $data = $(data);
            if($data.length){
                $("#ajax-posts").append($data);
                $("#more_posts").attr("disabled",false);
            } else{
                $("#more_posts").attr("disabled",true);
            }
        },
        error : function(jqXHR, textStatus, errorThrown) {
            $loader.html(jqXHR + " :: " + textStatus + " :: " + errorThrown);
        }

    });
    return false;
}

$("#more_posts").on("click",function(){ // When btn is pressed.
    $("#more_posts").attr("disabled",true); // Disable the button, temp.
    load_posts();
});

保存它,测试它,它的工作原理:)

图片作为证明(不要介意粗制滥造的造型,它很快就完成了)。帖子内容也是胡言乱语xD

在此处输入图片说明

在此处输入图片说明

在此处输入图片说明

更新

对于“无限加载”而不是按钮上的单击事件(只需使其不可见,使用visibility: hidden;),您可以尝试使用

$(window).on('scroll', function () {
    if ($(window).scrollTop() + $(window).height()  >= $(document).height() - 100) {
        load_posts();
    }
});

load_posts()当您距离页面底部 100 像素时,这应该会运行该函数。在我网站上的教程的情况下,您可以添加检查以查看帖子是否正在加载(以防止触发 ajax 两次),并且您可以在滚动到达页脚顶部时触发它

$(window).on('scroll', function(){
    if($('body').scrollTop()+$(window).height() > $('footer').offset().top){
        if(!($loader.hasClass('post_loading_loader') || $loader.hasClass('post_no_more_posts'))){
                load_posts();
        }
    }
});

现在在这些情况下唯一的缺点是您永远无法滚动到$(document).height() - 100$('footer').offset().top由于某种原因的值如果发生这种情况,只需增加滚动到的数字。

您可以通过将console.logs 放入代码中轻松检查它并在检查器中查看它们抛出的内容

$(window).on('scroll', function () {
    console.log($(window).scrollTop() + $(window).height());
    console.log($(document).height() - 100);
    if ($(window).scrollTop() + $(window).height()  >= $(document).height() - 100) {
        load_posts();
    }
});

并相应地调整;)

希望这会有所帮助:) 如果您有任何问题,请提问。

感谢您的回复,functions.php 部分中的某些内容破坏了整个站点,我不知道查看它会发生什么,但是如果我删除该功能,该站点将再次运行。
2021-03-15 10:04:20
如果我从函数中删除这些行而不是站点再次工作,那么我猜这里有一个错误: while ($loop->have_posts()) { $loop->the_post(); $out .= '<div class="small-12 large-4 columns"> <h1>'.get_the_title().'</h1> <p>'.get_the_content().'</p> </div>'; } endwhile; endif;
2021-03-20 10:04:20
我现在就解决这个问题^^
2021-03-24 10:04:20
值得注意的是,如果使用type: "POST",in$.ajax不起作用data: str,,要么更改为type: "GET"要么使用data: { cat : cat, pageNumber : pageNumber },
2021-04-04 10:04:20

如果我不使用任何类别,那么如何使用此代码?实际上,我想将此代码用于自定义帖子类型。

嘿,这不是一个有公开讨论的经典论坛。您使用“答案”字段提出另一个问题。下次,尝试在相关答案的评论中提出您的问题(“添加评论”)。
2021-04-05 10:04:20
谢谢你的建议。
2021-04-06 10:04:20