Question

Nous avons une page asp.NET qui programmaticaly l'ajout de données en tant que nouveaux éléments de liste dans une liste non ordonnée ..

Je veux utiliser certains jquery pour montrer un panneau coulissant de détail supplémentaire pour chaque élément de la liste, mais le code que je utilise montre que la première de la série (comme je devine parce qu'ils sont appelés la même chose). . Comment puis-je ajouter des conditions à choisir la bonne?

Voici le code:

 
$(document).ready(function(){

    $(".btn-slide").click(function(){
        $(this).slideToggle("slow");
        $(this).toggleClass("active"); return false;
    });

});
 

 
#panel {
    background: #754c24;
    height: 200px;
    display: none;
}
.slide {
    margin: 0;
    padding: 0;
    border-top: solid 4px #422410;
    background: #000 no-repeat center top;
}
.btn-slide {
    background: url(images/white-arrow.gif) no-repeat right -50px;
    text-align: center;
    width: 144px;
    height: 31px;
    padding: 10px 10px 0 0;
    margin: 0 auto;
    display: block;
    font: bold 120%/100% Arial, Helvetica, sans-serif;
    color: #fff;
    text-decoration: none;
}
.active {
    background-position: right 12px;
}

    <% foreach( var registration in ViewModel ) { %>
            <li>
             Event: <%= registration.Event.Name %>
             Date: <%= registration.Event.Date.ToLongDateString() %>
             <div id="panel">
              <% if ( registration.HasResult )  { %>
                 Your result for this event:
                 Place: <%= registration.Result.Place %>
                 Time: <%= registration.Result.Time %>
                 Average Pace: <%= registration.Result.AveragePace %>
              <% } else { %>
                 No results have been posted for this event.

              <% } %>
              </div>                  
              <p class="slide"><a href="#" class="btn-slide">Slide Panel</a></p> 
            </li>            
    <% } %>
</ul>

Était-ce utile?

La solution

Modifier la div à utiliser la classe de panneau au lieu de id.

 <div class="panel">

Ensuite, basculer la diapositive comme ceci:

 $('.panel', $(this).parent().parent()).slideToggle("slow");

Cela obtenir le div avec le panneau de classe qui existe dans le parent du parent de l'ancre.

Autres conseils

Vous pouvez le faire avec la méthode each ...

$(document).ready(function(){
    $(".btn-slide").each(
        function(){ $(this).click(function(){
         $(this).slideToggle("slow");
         $(this).toggleClass("active"); return false;
        });
    );
});

ID des éléments HTML doivent être uniques pour que votre boucle est produit HTML non valide. Essayez d'attribuer une classe à la place d'un ID à votre DIV.

.panel {
    background: #754c24;
    height: 200px;
    display: none;
}

<% foreach( var registration in ViewModel ) { %>

    <li>
     Event: <%= registration.Event.Name %>
     Date: <%= registration.Event.Date.ToLongDateString() %>
     <div class="panel">
      <% if ( registration.HasResult )  { %>
         Your result for this event:
         Place: <%= registration.Result.Place %>
         Time: <%= registration.Result.Time %>
         Average Pace: <%= registration.Result.AveragePace %>
      <% } else { %>
         No results have been posted for this event.
      <% } %>
      </div>
      <p class="slide"><a href="#" class="btn-slide">Slide Panel</a></p>
     </li>
<% } %>

Mise à jour : Aussi votre javascript ne semble pas correcte:

$(document).ready(function(){

    $(".btn-slide").click(function(){
        $(this).closest('li').find('.panel').slideToggle("slow");
        $(this).toggleClass("active");
         return false;
    });

});
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top