web-dev-qa-db-fra.com

Ajoutez la classe "active" uniquement au premier élément de boucle dans une requête WordPress

J'ai une requête comme ci-dessous:

<?php
    $query = new WP_Query( $wpplnum );

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

<div class="carousel-item col-md-4 active">
  <div class="card">
    <img class="card-img-top img-fluid" src="http://placehold.it/800x600/f44242/fff" alt="Card image cap">
    <div class="card-body">
      <h4 class="card-title">Card 1</h4>
      <p class="card-text">This is a longer card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
      <p class="card-text"><small class="text-muted">Last updated 3 mins ago</small></p>
    </div>
  </div>
</div>

Je veux ajouter la classe active uniquement au premier élément de boucle:

class="carousel-item col-md-4 active"

les éléments de boucle restants seront sans la classe active:

class="carousel-item col-md-4"

2
Latheesh V M Villa

J'utiliserais la propriété current_post de l'instance de classe WP_Query, qui dans votre cas est le $query. Donc ici je vérifie si $query->current_post est supérieur ou égal à 1:

<div class="carousel-item col-md-4 <?php echo $query->current_post >= 1 ? '' : 'active'; ?>">

Ressource: https://codex.wordpress.org/Class_Reference/WP_Query#Properties

3
Sally CJ

Voulez-vous dire quelque chose comme ce qui suit?

$query = new WP_Query($wpplnum);

$first = TRUE;

while($query->have_posts()):$query->the_post();

   $class = "";
   if($first)
   {
      $class = "active";
      $first = FALSE;
   }
?>

   <div class="carousel-item col-md-4 <?php echo esc_attr( $class ); ?>">

     .....

   </div>
1
user141080