Nettus + a ce nice jQuery code pour filtrer et afficher des <li>
s spécifiques à partir d'un <ul>
lorsqu'une catégorie est cliquée. Par exemple, lorsque vous cliquez sur le lien 'design', seuls les 'modèles' <li>
s sont affichés et le reste du portefeuille <li>
s est masqué. Cependant, quand je le combine avec une lightbox comme Yoxview (visualiseur d'image jQuery plugin), la lightbox montre les <li>
s de l'ensemble du portefeuille au lieu de montrer simplement la catégorie spécifique qui a été cliquée et filtrée.Impossible d'obtenir une lightbox pour ignorer les éléments cachés dans une liste dynamique jQuery
Comment puis-je obtenir la visionneuse pour afficher uniquement les <li>
s qui sont actuellement affichés sur la page et ignorer les <li>
s cachés? Merci pour toute aide.
$(document).ready(function() {
$('ul#filter a').click(function() {
$(this).css('outline','none');
$('ul#filter .current').removeClass('current');
$(this).parent().addClass('current');
var filterVal = $(this).text().toLowerCase().replace(' ','-');
if(filterVal == 'all') {
$('ul#portfolio li.hidden').fadeIn('slow').removeClass('hidden');
} else {
$('ul#portfolio li').each(function() {
if(!$(this).hasClass(filterVal)) {
$(this).fadeOut('normal').addClass('hidden');
} else {
$(this).fadeIn('slow').removeClass('hidden');
}
});
}
return false;
});
});
<ul id="filter">
<li class="current"><a href="#">All</a></li>
<li><a href="#">Design</a></li>
<li><a href="#">Development</a></li>
<li><a href="#">CMS</a></li>
<li><a href="#">Integration</a></li>
</ul>
<ul id="portfolio">
<li class="cms integration">
<a href="#"><img src="images/a-list-apart.png" />A List Apart</a>
</li>
<li class="integration design">
<a href="#"><img src="images/apple.png" />Apple</a>
</li>
<li class="design development">
<a href="#"><img src="images/cnn.png" />CNN</a>
</li>
<li class="cms">
<a href="#"><img src="images/digg.png" />Digg</a>
</li>
<li class="design cms integration">
<a href="#"><img src="images/espn.png" />ESPN</a>
</li>
</ul>
Merci pour la réponse. L'utilisation du: sélecteur de filtre visible fonctionne, mais quand la boîte à lumière apparaît, elle montre chaque li à la fois (l'utilisateur doit cliquer et fermer chacun d'eux) au lieu de les regrouper pour qu'ils puissent être affichés comme un diaporama. La lightbox doit être dite au #ul_id afin qu'elle puisse les regrouper. Donc, en utilisant #ul_id li: visible fait de chaque li son propre groupe. Je ne comprends pas pourquoi la lightbox n'ignore pas les éléments cachés dynamiquement dans le ul. – BobbyJackDougan