在我的情况下,我需要通过元素和各种手段进行过滤,几乎是有效的。
有一个用户可以选择的颜色列表。可以选择多个颜色。每个元素可以有一个或多个这些属性分配给它。
属性示例:
<div data-wotc-color="G">
<div data-wotc-color="B">
<div data-wotc-color="U">
<div data-wotc-color="UB">
<div data-wotc-color="U">
<div data-wotc-color="W">
In JQuery我这样做是为了通过使用filter():来显示/隐藏
$.each($('.colorpicker a'), function() {
if ($(this).hasClass('selected')) {
$('.pac').filter('[data-wotc-color*="' + $(this).attr('id') + '"]').show();
} else {
$('.pac').filter('[data-wotc-color*="' + $(this).attr('id') + '"]').hide();
}
});
基本上,所发生的事情(据我所见)是当您选择一个元素时,它可以显示/隐藏元素。当选择多个时,只要您按正确的顺序选择它,它就会正确地显示/隐藏。我知道这里可能需要某种正则表达式,但我不完全确定如何使用JQuery实现它。
发布于 2011-12-09 09:58:51
问题是,对于,每个锚点都是隐藏的,这些元素可能已经(合法地)显示了。
相反,隐藏所有内容,然后显示所选颜色的内容:
// Hide EVERYTHING
$('.pac').hide();
// Now show everything that matches:
$('.colorpicker a.selected').each(function() {
$('.pac').filter('[data-wotc-color*="' + $(this).attr('id') + '"]').show();
});
https://stackoverflow.com/questions/8449656
复制