我正在尝试在我正在构建的网站上使用jQuery同位素插件(http://isotope.metafizzy.co)。在本质上,我想要做的是过滤我已设法做的结果。但是,当我过滤结果时,我不希望其他结果消失,我只想让过滤后的选项出现在前面。
我一直在摸不着头脑。 这是我的jQuery:
$(function(){
var $container = $('#cards');
$container.isotope({
itemSelector : '.blank'
});
var $optionSets = $('#options .option-set'),
$optionLinks = $optionSets.find('a');
$optionLinks.click(function(){
var $this = $(this);
if ( $this.hasClass('selected') ) {
return false;
}
var $optionSet = $this.parents('.option-set');
$optionSet.find('.selected').removeClass('selected');
$this.addClass('selected');
var options = {},
key = $optionSet.attr('data-option-key'),
value = $this.attr('data-option-value');
value = value === 'false' ? false : value;
options[ key ] = value;
if ( key === 'layoutMode' && typeof changeLayoutMode === 'function' ) {
changeLayoutMode( $this, options )
} else {
$container.isotope( options );
}
return false;
});
});
和我的(简体)html:
<section id="options" class="clearfix">
<ul id="filters" class="option-set clearfix" data-option-key="filter">
<li><a href="#filter" data-option-value="*" class="selected">show all</a></li>
<li><a href="#filter" data-option-value=".christmas">Christmas</a></li>
<li><a href="#filter" data-option-value=".birthday">Birthday</a></li>
<li><a href="#filter" data-option-value=".thank-you">Thank You</a></li>
</ul>
<div id="cards">
<div class="blank christmas"></div>
<div class="blank christmas"></div>
<div class="blank christmas"></div>
<div class="blank christmas"></div>
<div class="blank birthday"></div>
<div class="blank birthday"></div>
<div class="blank birthday"></div>
<div class="blank thank-you"></div>
<div class="blank thank-you"></div>
和JSfiddle上的链接(虽然动画似乎没有用 - 但它在我的网站上运行所以没有问题):http://jsfiddle.net/Yvv5x/3/
任何帮助将不胜感激。
答案 0 :(得分:1)
这是工作fiddle。
你实际上不需要过滤,而是排序。因此,我创建了三种不同的排序情境(圣诞节,生日和谢谢你),每个项目都有相应的data- *属性(最终你可以通过代码设置这个属性)。
此外,您正在致电
$container.isotope({
itemSelector : '.blank'
});
一开始,没有所有必需的选项。