Como fazer comentários funcionarem para uma postagem carregada pelo Ajax?


10

Atualmente, estou carregando uma única postagem usando ajax. Enquanto o carregamento do post funciona bem, não consigo carregar os comentários. Aqui está o meu código:

Meu javascript para carregar a postagem:

<script>
$(".view_post").click(function(e) {
    e.preventDefault();
    postid = $(this).attr("rel");
    $.ajax({
        url:"/wp-admin/admin-ajax.php",
        type:'POST',
        data:'action=posts_open&postid='+postid,
        success: function(html){
            $("#b_contentwrapper").empty();
            $("#b_contentwrapper").append(html);
        }
    });
});
</script>

O javascript passa por functions.php desta maneira:

function implement_posts()
{
    //<?php
    get_template_part( 'loop', 'single' );
    die();
}

Agora, aqui está o código em que eu realmente carrego meu conteúdo de postagem:

<?php
    $linkid = "p=".$_POST["postid"];
    $posti = new WP_Query($linkid);
    $posti->the_post();
    echo "Time: ";
    the_time('F jS, Y');
    echo "<br />";
    the_category(', ');
    echo "<br />";
    the_title();
    echo "<br />";
    the_content();
    echo "<br />";
    comment_form();
    ?>
    </div>
    <?php if (have_comments()) {
        echo "Comments ok";
    }
    else
    {
        echo "No comments";
    }
    ?>

Agora, mesmo para postagens com comentários, estou recebendo "Nenhum comentário" exibido. Tudo o resto funciona corretamente. Alguém pode me ajudar?

Obrigado.


$linkid = "p=".$_POST["postid"];não é seguro para injeção de verry sql. embora o wordpess verifique isso, você pode querer fazer isso sozinho.
RTB

Respostas:


1

Para citar o Codex na have_commentsfunção:

Essa função depende do objeto global $ wp_query a ser definido - esse geralmente é o caso no Loop

O problema é que seu manipulador ajax cria seu próprio objeto WP_Query. Observe que você não está ligando the_post(), mas sim $posti->the_post(). A mesma lógica se aplica aos comentários também.

Tente o seguinte:

if ($posti->have_comments()) {
    echo "Comments ok";
}  else {
    echo "No comments";
}

0

Na minha opinião, seria melhor usar um JQuery .load($[this].attr('href') '.div-with-content-and-comment');

Depois, verifique se você possui um single.php com a marcação que class="div-with-content-and-comment"você deseja carregar via ajax.


0

Veja a fonte de have_comments()- essa verificação recupera dados do $wp_queryobjeto global , que não é usado no seu caso.

Portanto, o primeiro passo seria substituir o have_comments()cheque por $posti->have_comments().

Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.