我正在使用带有复选框组合过滤器的Isotope.js创建应用程序。我正在努力使用示例等工作。
但是我发现了如何隐藏某些过滤器的问题,这些过滤器不会对过滤器产生任何结果。
我创建了一个JSFiddle来演示我的例子。
过滤选项:
<div id="options">
<div class="option-set" data-group="brand">
<input type="checkbox" value="" id="brand-all" class="all" checked /><label for="brand-all">all brands</label>
<input type="checkbox" value=".brand1" id="brand1" /><label for="brand1">brand1</label>
<input type="checkbox" value=".brand2" id="brand2" /><label for="brand2">brand2</label>
</div>
<div class="option-set" data-group="type">
<input type="checkbox" value="" id="type-all" class="all" checked /><label for="type-all">all types</label>
<input type="checkbox" value=".type1" id="type1" /><label for="type1">type1</label>
<input type="checkbox" value=".type2" id="type2" /><label for="type2">type2</label>
</div>
</div>
产品:
<div id="container">
<div class="item brand1 type1 red"></div>
<div class="item brand1 type1 red"></div>
<div class="item brand1 type1 red"></div>
<div class="item brand2 type2 blue"></div>
<div class="item brand2 type2 blue"></div>
<div class="item brand2 type2 blue"></div>
</div>
在我的例子中,我有两个过滤器品牌和类型。如果选择品牌1作为过滤器,则只有该品牌的第1类可用,因此我希望隐藏第2类复选框,如果选择了全部,则反之亦然。
对于任何类别而非硬编码类别,它应该以可扩展的方式工作。
我已经尝试通过在过滤器上触发同位素本身来实现这一点,但是没有奏效。还可以在排列完成时创建事件,但仍然无法从过滤的项目中获取可用的类别。
安排我尝试使用的项目的方法:
$$container.on( 'arrangeComplete', function( event, filteredItems ) {
filteredItems.forEach(function(elementsData){
console.log($(elementsData.element).attr('class));
});
});
有人可以引导我找到正确的解决方案,因为我已经花了好几个小时尝试不同的激活。
答案 0 :(得分:0)
试试这个:
/*jshint browser:true, undef: true, unused: true, jquery: true */
var $container;
var filters = {};
$(function(){
$container = $('#container');
var $filterDisplay = $('#filter-display');
$container.isotope();
// do stuff when checkbox change
$('#options').on( 'change', function( jQEvent ) {
var $checkbox = $( jQEvent.target );
manageCheckbox( $checkbox );
var comboFilter = getComboFilter( filters );
$container.isotope({ filter: comboFilter });
$filterDisplay.text( comboFilter );
var comboFilters = comboFilter.split(', ');
$(comboFilters).each(function(edx, val) {
var myval = val;
var hidelist = [];
var showlist = [];
$('.option-set input').each(function(edx, ele) {
var selector = $(ele).attr("value") + myval;
if(selector !== "" && $(selector).length === 0)
{
hidelist.push(ele);
//$(ele).hide();
//$("label[for='"+$(ele).attr('id')+"']").hide();
}
else {
showlist.push(ele);
}
});
$(hidelist).each(function(edx, item) {
$(item).hide();
$("label[for='"+$(item).attr('id')+"']").hide();
});
$(showlist).each(function(edx, item) {
$(item).show();
$("label[for='"+$(item).attr('id')+"']").show();
});
});
});
});
function getComboFilter( filters ) {
var i = 0;
var comboFilters = [];
var message = [];
for ( var prop in filters ) {
message.push( filters[ prop ].join(' ') );
var filterGroup = filters[ prop ];
// skip to next filter group if it doesn't have any values
if ( !filterGroup.length ) {
continue;
}
if ( i === 0 ) {
// copy to new array
comboFilters = filterGroup.slice(0);
} else {
var filterSelectors = [];
// copy to fresh array
var groupCombo = comboFilters.slice(0); // [ A, B ]
// merge filter Groups
for (var k=0, len3 = filterGroup.length; k < len3; k++) {
for (var j=0, len2 = groupCombo.length; j < len2; j++) {
filterSelectors.push( groupCombo[j] + filterGroup[k] ); // [ 1, 2 ]
}
}
// apply filter selectors to combo filters for next group
comboFilters = filterSelectors;
}
i++;
}
var comboFilter = comboFilters.join(', ');
return comboFilter;
}
function manageCheckbox( $checkbox ) {
var checkbox = $checkbox[0];
var group = $checkbox.parents('.option-set').attr('data-group');
// create array for filter group, if not there yet
var filterGroup = filters[ group ];
if ( !filterGroup ) {
filterGroup = filters[ group ] = [];
}
var isAll = $checkbox.hasClass('all');
// reset filter group if the all box was checked
if ( isAll ) {
delete filters[ group ];
if ( !checkbox.checked ) {
checkbox.checked = 'checked';
}
}
// index of
var index = $.inArray( checkbox.value, filterGroup );
if ( checkbox.checked ) {
var selector = isAll ? 'input' : 'input.all';
$checkbox.siblings( selector ).removeAttr('checked');
if ( !isAll && index === -1 ) {
// add filter to group
filters[ group ].push( checkbox.value );
}
} else if ( !isAll ) {
// remove filter from group
filters[ group ].splice( index, 1 );
// if unchecked the last box, check the all
if ( !$checkbox.siblings('[checked]').length ) {
$checkbox.siblings('input.all').attr('checked', 'checked');
}
}
}