gpt4 book ai didi

javascript - 使用多个复选框进行 Jquery 过滤

转载 作者:行者123 更新时间:2023-12-01 01:58:04 25 4
gpt4 key购买 nike

对于当前项目,我正在创建一个简单的产品目录,该目录应该能够通过带有多组复选框的 Jquery 进行过滤。

在一组中,当选中两个或更多复选框时,逻辑应为“或”,而当使用两组或更多组复选框时,逻辑应为“与”。

我当前正在使用的一个很好的(并且有效的)示例可以在这里找到:

https://stackoverflow.com/a/22941156/5567735

JSFIDDLE

if (cselector === '' && nselector === '') {
$('.flowers > div').filter(selector).show();
} else if (cselector === '') {
$('.flowers > div').filter(selector).filter(nselector).show();
} else if (nselector === '') {
$('.flowers > div').filter(selector).filter(cselector).show();
} else {
$('.flowers > div').filter(selector).filter(cselector).filter(nselector).show();
}

我的问题涉及这部分代码,其中在选择过滤器的情况下使用过滤器。现在,这对于示例中使用的 3 个过滤器来说效果非常好。我想知道是否有更好的方法来做到这一点?就我而言,我想添加更多过滤器,然后当我必须添加更多 if 语句时,这部分代码很快就会变得困惑。

所以基本上我的问题是:使用此设置,您将如何添加更多过滤器,以便最终有 6 或 7 个而不是当前的 3 个?

非常感谢,彼得

附注我也很欣赏完全不同方法的提示,但由于我已经投入了相当多的时间,所以我真的很想让它以这种方式工作。

最佳答案

您当前的方法不是很动态,选择器和数组都是硬编码的,因此每次添加新的过滤器选项时,您都必须添加代码来处理它。

相反,只需将更改处理程序绑定(bind)到所有过滤器复选框,您就可以收集它们的值,并按各自的名称对它们进行分组,例如:

var $filterCheckboxes = $( '.filter-checkboxes' );

$filterCheckboxes.on( 'change', function() {

var selectedFilters = {};

$filterCheckboxes.filter( ':checked' ).each( function() {

if ( ! selectedFilters.hasOwnProperty( this.name ) ) {
selectedFilters[ this.name ] = [];
}

selectedFilters[ this.name ].push( this.value );

} );

} );

这将创建一个包含输入名称 -> 值数组对的对象,例如:

selectedFilters = {
'fl-colour': [ 'red', 'green' ],
'fl-size': [ 'tiny' ]
};

然后,您可以循环遍历每个 selectedFilters,并过滤您的 .flower 元素。如果 .flower 元素与每个命名集中的值匹配,我们将返回 true,以便该元素包含在 $filteredResults 集合中:

// create a collection containing all of the filterable elements
var $filteredResults = $( '.flower' );

// loop over the selected filter name -> (array) values pairs
$.each( selectedFilters, function( name, filterValues ) {

// filter each .flower element
$filteredResults = $filteredResults.filter( function() {

var matched = false,
currentFilterValues = $( this ).data( 'category' ).split( ' ' );

// loop over each category value in the current .flower's data-category
$.each( currentFilterValues, function( _, currentFilterValue ) {

// if the current category exists in the selected filters array
// set matched to true, and stop looping. as we're ORing in each
// set of filters, we only need to match once

if ( $.inArray( currentFilterValue, filterValues) != -1 ) {
matched = true;
return false;
}

} );

// if matched is true the current .flower element is returned
return matched;

} );

} );

然后只需隐藏所有 .flower 元素,并显示 $filteredResults,例如:

$( '.flower' ).hide().filter( $filteredResults ).show();

Here's an example fiddle

关于javascript - 使用多个复选框进行 Jquery 过滤,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35011034/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com