隐藏没有组合结果的过滤器同位素JS

时间:2018-02-15 12:05:22

标签: javascript jquery jquery-isotope isotope

我正在使用带有复选框组合过滤器的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));
});
});

有人可以引导我找到正确的解决方案,因为我已经花了好几个小时尝试不同的激活。

1 个答案:

答案 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');
    }
  }

}

Fiddler:https://jsfiddle.net/Lsg4zxu7/45/