Usando ajax em categorias e loops wordpress

3

Eu quero que meu index.php seja uma página simples com uma lista horizontal de nomes de categorias no topo. Mas, em vez de recarregar a página com a lista de postagens nesse loop sempre que uma categoria é clicada, desejo que o conjunto de postagens de cada categoria seja exibido instantaneamente após cada clique em uma categoria diferente. Isso é possível no Wordpress?

    
por LND 08.12.2011 / 07:53

1 resposta

10

Sim, isso é possível com o WordPress, mas eu não usaria index.php, mas um modelo front-page.php personalizado, em seguida, crie uma página chamada home e defina-a como a primeira página nas opções gerais.

Para o seu menu de categorias:

<?php

$categories = get_categories(); ?>

<ul id="category-menu">
    <?php foreach ( $categories as $cat ) { ?>
    <li id="cat-<?php echo $cat->term_id; ?>"><a class="<?php echo $cat->slug; ?> ajax" onclick="cat_ajax_get('<?php echo $cat->term_id; ?>');" href="#"><?php echo $cat->name; ?></a></li>

    <?php } ?>
</ul>

Ao chamar nossa função ajax do jQuery quando uma categoria é clicada e passando o ID do cat para jQuery no nome da função.

O marcador de espaço html div onde suas postagens serão carregadas via ajax:

<div id="loading-animation" style="display: none;"><img src="<?php echo admin_url ( 'images/loading-publish.gif' ); ?>"/></div>
<div id="category-post-content"></div>

A função jQuery chamada por meio do manipulador onclick nos itens de menu:

<script>
function cat_ajax_get(catID) {
    jQuery("a.ajax").removeClass("current");
    jQuery("a.ajax").addClass("current"); //adds class current to the category menu item being displayed so you can style it with css
    jQuery("#loading-animation").show();
    var ajaxurl = '<?php echo admin_url( 'admin-ajax.php' ); //must echo it ?>';
    jQuery.ajax({
        type: 'POST',
        url: ajaxurl,
        data: {"action": "load-filter", cat: catID },
        success: function(response) {
            jQuery("#category-post-content").html(response);
            jQuery("#loading-animation").hide();
            return false;
        }
    });
}
</script>

A função PHP do WordPress para retornar as postagens da categoria selecionada.

add_action( 'wp_ajax_nopriv_load-filter', 'prefix_load_cat_posts' );
add_action( 'wp_ajax_load-filter', 'prefix_load_cat_posts' );
function prefix_load_cat_posts () {
    $cat_id = $_POST[ 'cat' ];
         $args = array (
        'cat' => $cat_id,
        'posts_per_page' => 10,
        'order' => 'DESC'

    );

    $posts = get_posts( $args );

    ob_start ();

    foreach ( $posts as $post ) {
    setup_postdata( $post ); ?>

    <div id="post-<?php echo $post->ID; ?> <?php post_class(); ?>">
        <h1 class="posttitle"><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a></h1>

        <div id="post-content">
        <?php the_excerpt(); ?>
        </div>

   </div>

   <?php } wp_reset_postdata();

   $response = ob_get_contents();
   ob_end_clean();

   echo $response;
   die(1);
   }

Estamos usando o buffer de saída que ajuda a evitar que a função falhe, o que pode acontecer às vezes com o WordPress Ajax.

    
por Chris_O 11.12.2011 / 05:08

Tags