我正在尝试了解如何将Combination filters与Jquery BBQ Hash History一起使用。
我想要做的是按照徽标,身份或品牌进行用户过滤。如果用户点击Logos,我希望他们能够通过“非营利,教育,零售”等进行子过滤。我知道组合过滤器工作正常而没有实现jquery BBQ代码,但我想两者都做。
$optionSets.find('.filter-main a').click(function(){
var $this = $(this);
// don't proceed if already selected
if ( $this.hasClass('selected') ) {
return;
}
changeSelectedLink( $this );
// get href attr, remove leading #
var href = $this.attr('href').replace( /^#/, '' ),
// convert href into object
// i.e. 'filter=.inner-transition' -> { filter: '.inner-transition' }
option = $.deparam( href, true );
// apply new option to previous
$.extend( isotopeOptions, option );
// set hash, triggers hashchange on window
$.bbq.pushState( isotopeOptions );
isOptionLinkClicked = true;
return false;
});
答案 0 :(得分:4)
请参阅http://support.metafizzy.co/2011/isotope-combo-filters-hash-links.html
$(function(){
var $container = $('#container'),
filters = {},
// get filter from hash, remove leading '#'
filterSelector = window.location.hash.slice(1);
$('#filters a').click(function(){
// store filter value in object
// i.e. filters.color = 'red'
var $this = $(this),
name = $this.attr('data-filter-name'),
value = $this.attr('data-filter-value'),
isoFilters = [],
filterName, prop;
filters[ name ] = value;
for ( prop in filters ) {
isoFilters.push( filters[ prop ] );
}
var filterSelector = isoFilters.join('');
// trigger isotope if its ready
if ( $container.data('isotope') ) {
$container.isotope({ filter: filterSelector });
}
window.location.hash = filterSelector;
// toggle highlight
$this.parents('ul').find('.selected').removeClass('selected');
$this.parent().addClass('selected');
return false;
});
// if there was a filter, trigger a click on the
// corresponding option
if ( filterSelector ) {
var selectorClasses = filterSelector.split('.').slice(1);
$.each( selectorClasses, function( i, selectorClass ) {
$('#filters a[data-filter-value=".' + selectorClass + '"]').click();
});
}
$('#container').isotope({
itemSelector: '.item',
filter: filterSelector,
masonry: {
columnWidth: 80
}
});
});