- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在为网上商店构建产品过滤器。目前有 3 个类别(产品属性),但类别的数量可能会有所不同。我已经完成了这项看似简单的任务,但没有 100% 适合我需要的解决方案。搜索 SO 但找不到与我的问题完全匹配的内容。
现在我有一些代码可以工作,它只显示具有确切属性的产品。问题是这太局限了。
这是我现在用来过滤产品的代码,过滤器不需要从服务器获取数据,所有产品都可用并且具有过滤器值的类:
JS
$('.choice_form').change(function(evt){
var filter = $(':input:checked,select').map(function(index, el) {
return "." + el.value;
}).toArray().join("");
$(".vis-products").hide().filter(filter).show();
});
HTML:
<div class="categories default-text">
<!-- choice help -->
<div class="choicehelp-wrapper">
<b class="black">Basisdeel</b><br><label class="noselect choicehelp_text"><input type="checkbox" name="choice_option[]" value="ft12" class="choice_form js" data-group="product" data-action="choicehelp" data-value="12" data-id="1" style="margin:6px 0px 6px 0px"> Kunststof, zwart</label><br>
<label class="noselect choicehelp_text"><input type="checkbox" name="choice_option[]" value="ft13" class="choice_form js" data-group="product" data-action="choicehelp" data-value="13" data-id="1" style="margin:6px 0px 6px 0px"> Messing, nikkel</label><br><br><b class="black">Insteek</b><br>
<label class="noselect choicehelp_text"><input type="checkbox" name="choice_option[]" value="ft11" class="choice_form js" data-group="product" data-action="choicehelp" data-value="11" data-id="2" style="margin:6px 0px 6px 0px"> Knie insteek koppeling</label><br><label class="noselect choicehelp_text"><input type="checkbox" name="choice_option[]" value="ft9" class="choice_form js" data-group="product" data-action="choicehelp" data-value="9" data-id="2" style="margin:6px 0px 6px 0px"> Rechte inschroef koppeling</label><br>
<label class="noselect choicehelp_text"><input type="checkbox" name="choice_option[]" value="ft10" class="choice_form js" data-group="product" data-action="choicehelp" data-value="10" data-id="2" style="margin:6px 0px 6px 0px"> T-inschroef koppeling</label><br><br><b class="black">Inschroef</b><br>
<label class="noselect choicehelp_text"><input type="checkbox" name="choice_option[]" value="ft7" class="choice_form js" data-group="product" data-action="choicehelp" data-value="7" data-id="3" style="margin:6px 0px 6px 0px"> M4 Diameter</label><br><label class="noselect choicehelp_text"><input type="checkbox" name="choice_option[]" value="ft4" class="choice_form js" data-group="product" data-action="choicehelp" data-value="4" data-id="3" style="margin:6px 0px 6px 0px"> M5 Diameter</label><br>
<label class="noselect choicehelp_text"><input type="checkbox" name="choice_option[]" value="ft6" class="choice_form js" data-group="product" data-action="choicehelp" data-value="6" data-id="3" style="margin:6px 0px 6px 0px"> M8 Diameter</label><br><label class="noselect choicehelp_text"><input type="checkbox" name="choice_option[]" value="ft8" class="choice_form js" data-group="product" data-action="choicehelp" data-value="8" data-id="3" style="margin:6px 0px 6px 0px"> M9 Diameter</label> </div>
</div>
以及产品 html:
<div class="visnav3 vis-products vis-catalog js ft11 ft12 filterOn" data-group="product" data-action="goto-details" data-id="111111" data-value="DEMO-2" style="">....</div>
ftxx 类与复选框值相对应。
包含的有点太多了,你可以在这里查看: https://www.technicomponents.nl/nl/p/pneumatiek/insteekkoppelingen/knie-koppelingen/
它应该这样做:
情况 1。如果您只单击 1 个过滤器,则所有以该过滤器作为类名的产品都应该可见
情况 2。例如,如果您从 1 个类别中选择 2 个或更多过滤器,则所有具有所选过滤器作为类别的产品都应该可见。
案例 3. 如果您从多个类别中选择一个或多个值,它应该是这样的:
哪里
第 1 类:
- 过滤器 x OR
- 过滤 y 或
- 过滤 z 或
和
第 2 类:
- 过滤器 x OR
- 过滤 z 或
和
第 3 类:
- 过滤 y 或
- 过滤 z 或
当前代码仅在您选择 1 个值(来自一个或多个类别)时才有效。
最佳答案
您需要一种方法来了解 input
属于哪个组,这样您就知道何时应用 AND 逻辑,以及何时应用 OR 逻辑。在我看来,您在 data-id
属性中有这样的信息。我将假设此属性对于属于同一组的输入具有相等的值,并且当输入位于不同的组时它是不同的。 (如果这是不对的,只需选择能做出这种区分的东西)。
您可以使用 CSS 逗号执行 OR 运算。然后,AND 操作可以作为 jQuery 的 filter
方法的连续调用来执行。
这是这个想法的一个非常简化的演示:
$("input").change(function () {
var filters = {}; // key/value per group
$(':input:checked,select').each(function(index, el) {
var group = $(el).data("id"); // <-- something that identifies the group
filters[group] = (filters[group] || []).concat("." + el.value);
});
var $filtered = $(".vis-products").hide();
// Apply each filter on the result of the previous one:
for (var group in filters) $filtered = $filtered.filter(filters[group].join(","));
$filtered.show();
});
.filter {
width: 100px;
float: left;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.0/jquery.min.js"></script>
<div class="filter">
Cat 1:<br>
<input type="checkbox" data-id="1" value="a">a<br>
<input type="checkbox" data-id="1" value="b">b<br>
Cat 2:<br>
<input type="checkbox" data-id="2" value="i">i<br>
<input type="checkbox" data-id="2" value="j">j<br>
<input type="checkbox" data-id="2" value="k">k<br>
Cat 1:<br>
<input type="checkbox" data-id="3" value="x">x<br>
<input type="checkbox" data-id="3" value="y">y<br>
</div>
Data:<br>
<div class="vis-products a i x">a i x</div>
<div class="vis-products a i y">a i y</div>
<div class="vis-products a j x">a j x</div>
<div class="vis-products a j y">a j y</div>
<div class="vis-products a k x">a k x</div>
<div class="vis-products a k y">a k y</div>
<div class="vis-products b i x">b i x</div>
<div class="vis-products b i y">b i y</div>
<div class="vis-products b j x">b j x</div>
<div class="vis-products b j y">b j y</div>
<div class="vis-products b k x">b k x</div>
<div class="vis-products b k y">b k y</div>
关于javascript - 筛选多个类别的产品,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58592355/
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 9 个月前关闭。 Improve
我使用 partykit打包并遇到以下错误消息: Error in matrix(0, nrow = mi, ncol = nl) : invalid 'nrow' value (too large
我一直在尝试寻找一个量表或分类指标,为 VADER 情绪分析分配一些情感程度,而不仅仅是积极、消极或中性。如果有人可以分享他们的观点或资源来帮助按以下方式对 VADER 复合分数进行分类,我将非常感激
伙计们,我想自动循环..但我不知道是我放错了 while 还是循环错了? 我的数据库 标签:kt_barang kd_kategori | nama_kategori 1
我正在创建一个列出本地企业并按类别、子类别和关键字对它们进行分组的应用程序。以下是企业排序规则: 一个企业可以属于多个类别和子类别 一个企业可以有多个关键字 并非每个类别都有子类别,但有子类别的只有两
我有一系列单词 - 我的刺激 - 它们显示在屏幕上。然而,每个词都有另一个“条件”,即它们是类别 A、类别 B 或类别 C。这可能很简单,但我找不到答案并坚持下去。我的最终目标是在每次运行脚本时将类别
我正在使用 Laravel 5.5 和 MySql。如果不向 Services 表中添加 subCategoryID 列,我无法弄清楚如何将类别和子类别与服务相关联。 目前这是我的表结构 服务类别 i
我有两个部分/类别结构的链接表。 the section table structure id sec_title 1 section 1 2 section 2 the category str
我有一个类层次结构如下 @interface PTLDatasource : NSObject ... @interface PTLFetchedDatasource : PTLDatasource
我有一个 DataFrame df 一列,category 使用以下代码创建: import pandas as pd import random as rand from string import
我经常在多个类中设置获取请求以从核心数据(加上一些其他结果)中检索“allRecipes”或“lastModifiedDate”。 为此使用专门的类别 NSManagedObjectContext+R
可以在 Objective C 中创建类别之间的依赖关系吗?也在类别和它们的基类之间? 我知道在运行时应该没有区别,它们可能只是在编译时合并在一起。例如,假设我将 B 类分解为: B(base cla
这个问题在这里已经有了答案: 关闭 10 年前。
example img of a category selection by user 嘿,我正在尝试设置一个选择,用户必须选择一个类别和第二个类别,但我不知道如何获取他单击的信息。用户单击类别后,它
尝试将投资组合库添加到我正在制作的自定义 wp 主题中。我已经筋疲力尽地试图寻找甚至可以修改一些的解决方案和插件。我认为我在寻找解决方案时遇到的一个问题是我不完全确定哪些搜索词可以帮助我找到与我想要实
当我查看 Cocoa Touch API 时,我可以在同一个头文件中找到一些与类别一起声明的类,例如 @interface NSArray : NSObject @property (readonl
我的 log4j.properties 中有以下内容 log4j.rootLogger = debug, stdout, fileLog log4j.appender.stdout = org.apa
如果我在类中添加类别方法,比如NSXMLNode: @interface NSXMLNode (mycat) - (void)myFunc; @end NSXMLNode 的子类,例如 NSXMLEl
先说场景,wordpress的分类结构是这样的 Level 1: Top Level 2: -Nextme_1 Level 3: --Nextme_2 --Nextme_3 Leve
我有一个解析网络,现在我想浏览标签,或显示图表。我怎样才能得到图表?或者在树中导航。显示第一步然后其他等。并了解这棵树是如何 build 的。 import urllib from lxml impo
我是一名优秀的程序员,十分优秀!