- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我制作了一个包含多个选项的过滤器。如您所见,有时没有结果。我将此作为用户反馈返回给访问者:没有结果。
现在我想做的是,如果某些组合由过滤器(某些值)组成,则只有在实际存在值时才可以使用过滤器(如果页面上没有值,则隐藏一个选项)。这样我就可以避免用户为了找到正确的结果而不得不进行无休止的过滤器组合。有人可以帮助我吗?
$("select.filterby").change(function() {
var filters = $.map($("select.filterby").toArray(), function(e) {
return $(e).val();
}).join(".");
$("div#FilterContainer").find("div.job-offer-card").hide();
if ($("div#FilterContainer").find("div.job-offer-card." + filters).length) {
$("div#FilterContainer").find("div.job-offer-card." + filters).show();
} else {
$("div#FilterContainer").find("div.noresults").show();
}
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<span> View by:</span>
<label for="location">Location</label>
<select id="location" class="filterby">
<option value="all">Show All</option>
<option value="australia">Australia</option>
<option value="singapore">Singapore</option>
<option value="newzealand">New Zealand</option>
<option value="usa">USA</option>
<option value="uk">UK</option>
<option value="vietnam">Vietnam</option>
<option value="global">Global</option>
<option value="othercountry">Other</option>
</select>
<label for="type">Type</label>
<select id="type" class="filterby">
<option value="all">Show All</option>
<option value="accommodation">Accommodation</option>
<option value="app">App/Technology</option>
<option value="business">Business</option>
<option value="health">Health</option>
<option value="hospitality">Hospitality</option>
<option value="education">Education</option>
<option value="retail">Retail</option>
<option value="services">Services</option>
<option value="travel">Travel</option>
</select>
<label for="code">Code</label>
<select id="code" class="filterby">
<option value="all">Show All</option>
<option value="001">001</option>
<option value="002">002</option>
<option value="003">003</option>
<option value="004">004</option>
</select>
<div id="FilterContainer">
<div class="job-offer-card noresults">
<p>no results</p>
</div>
<div class="job-offer-card all vietnam accommodation travel 004">
<p>1 all vietnam accommodation travel</p>
</div>
<div class="job-offer-card all vietnam travel 003">
<p>2 all vietnam travel</p>
</div>
<div class="job-offer-card all vietnam accommodation travel">
<p>3 all vietnam accommodation travel</p>
</div>
<div class="job-offer-card all australia accommodation travel 003">
<p>4 all australia accommodation travel</p>
</div>
<div class="job-offer-card all australia education">
<p>5 all australia</p>
</div>
<div class="job-offer-card all vietnam newzealand usa accommodation">
<p>6 all vietnam accommodation</p>
</div>
<div class="job-offer-card all vietnam accommodation travel">
<p>7 all vietnam accommodation travel</p>
</div>
<div class="job-offer-card all vietnam travel">
<p>8 all vietnam travel</p>
</div>
<div class="job-offer-card all vietnam accommodation travel">
<p>9 all vietnam accommodation travel</p>
</div>
<div class="job-offer-card all australia accommodation travel">
<p>10 all australia accommodation travel</p>
</div>
<div class="job-offer-card all australia health 001">
<p>11 all australia</p>
</div>
<div class="job-offer-card all vietnam accommodation 002">
<p>12 all vietnam accommodation</p>
</div>
</div>
最佳答案
显示动态选择和动态 FilterContainer 元素的解决方案。
备注:类名 001 ... 004 应更改为 _001 ..._004,因为它们不是有效的类名见 => Which characters are valid in CSS class names/selectors?
或者使用 dataset => https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/dataset 会更清楚
const
Selects = document.querySelectorAll('select') // 3 selects in this story
, mainFC = document.querySelector('#FilterContainer') // result part
, all_FC = document.querySelectorAll('#FilterContainer div') // details result part
, zeroFC = document.querySelector('#FilterContainer div.noresults') // when there is nothing
;
var PossibleOptions = new Set(); // set for all options feet in #FilterContainer div
all_FC.forEach(d=>{d.className.split(' ').forEach(c=>{PossibleOptions.add(c)})}) // first attempt
// for the start : set only options availables + onchange listener
Selects.forEach(s=>{ // for each Select
s.querySelectorAll('option').forEach(o=>{ // and for each option, in
o.disabled = !PossibleOptions.has(o.value); // is there 1 a result div using this class ?.
if (o.value==='all') o.selected=true; // start the select at position for all
})
s.onchange = SelecChange; // give listener 'change' to function named 'SelecChange'
})
function SelecChange(e) // for every select action...
{
// e.target.value
let // prepare ;
List_Selects = [] // - array for all selects value
, no_FC = true // - flag to know if there is no FS as result
;
PossibleOptions.clear(); // new start
Selects.forEach(s=>{ // make List_Selects
if(s.value!='all') // everything is nothing
{ List_Selects.push(s.value) } // add select value
});
all_FC.forEach(d=>{ // for each FilterContainer <div> as 'd'
let ok = true;
for(let cLS of List_Selects) // for each option choosed in a select
{ ok = ok && d.classList.contains(cLS) } // check if in class list of the <div>
if (ok){
d.classList.remove('noShow'); // so this div will be shown
d.className.split(' ').forEach(c=>{ PossibleOptions.add(c) });
// and all the div class item be added on the set
no_FC = false; // one is enough
}
else {
d.classList.add('noShow'); // soory guy, your not in the team for this time
}
})
// now we have disable all options witch as no reality in FilterContainer
Selects.forEach(s=>{
s.querySelectorAll('option').forEach(o=>{
o.disabled = !PossibleOptions.has(o.value); // PossibleOptions know
})
})
// last things: is there results ?
if (no_FC) { zeroFC.classList.remove('noShow') } // there is none
else { zeroFC.classList.add('noShow') } // there is one (or more)
}
.noShow { display: none }
<h4> View by:</h4>
<label for="location">Location</label>
<select id="location" class="filterby">
<option value="all">Show All</option>
<option value="australia">Australia</option>
<option value="singapore">Singapore</option>
<option value="newzealand">New Zealand</option>
<option value="usa">USA</option>
<option value="uk">UK</option>
<option value="vietnam">Vietnam</option>
<option value="global">Global</option>
<option value="othercountry">Other</option>
</select>
<label for="type">Type</label>
<select id="type" class="filterby">
<option value="all">Show All</option>
<option value="accommodation">Accommodation</option>
<option value="app">App/Technology</option>
<option value="business">Business</option>
<option value="health">Health</option>
<option value="hospitality">Hospitality</option>
<option value="education">Education</option>
<option value="retail">Retail</option>
<option value="services">Services</option>
<option value="travel">Travel</option>
</select>
<label for="code">Code</label>
<select id="code" class="filterby">
<option value="all">Show All</option>
<option value="001">001</option>
<option value="002">002</option>
<option value="003">003</option>
<option value="004">004</option>
</select>
<hr>
<div id="FilterContainer">
<div class="job-offer-card noresults noShow">
<p>no results</p>
</div>
<div class="job-offer-card all vietnam accommodation travel 004">
<p>1 all vietnam accommodation travel _004</p>
</div>
<div class="job-offer-card all vietnam travel _003">
<p>2 all vietnam travel _003</p>
</div>
<div class="job-offer-card all vietnam accommodation travel">
<p>3 all vietnam accommodation travel</p>
</div>
<div class="job-offer-card all australia accommodation travel 003">
<p>4 all australia accommodation travel 003</p>
</div>
<div class="job-offer-card all australia education">
<p>5 all australia education</p>
</div>
<div class="job-offer-card all vietnam newzealand usa accommodation">
<p>6 all vietnam newzealand usa accommodation</p>
</div>
<div class="job-offer-card all vietnam accommodation travel">
<p>7 all vietnam accommodation travel</p>
</div>
<div class="job-offer-card all vietnam travel">
<p>8 all vietnam travel</p>
</div>
<div class="job-offer-card all vietnam accommodation travel">
<p>9 all vietnam accommodation travel</p>
</div>
<div class="job-offer-card all australia accommodation travel">
<p>10 all australia accommodation travel</p>
</div>
<div class="job-offer-card all australia health 001">
<p>11 all australia health _001</p>
</div>
<div class="job-offer-card all vietnam accommodation 002">
<p>12 all vietnam accommodation _002</p>
</div>
</div>
相同的解决方案,但使用数据选项
=> <div class="job-offer-card" data-options="all vietnam accommodation 002">
( JS =>element.dataset.options)
const
Selects = document.querySelectorAll('select') // 3 selects in this story
, mainFC = document.querySelector('#FilterContainer') // result part
, all_FC = document.querySelectorAll('#FilterContainer div') // details result part
, zeroFC = document.querySelector('#FilterContainer div.noresults') // when there is nothing
;
var PossibleOptions = new Set(); // set for all options feet in #FilterContainer div
all_FC.forEach(d=>{ d.dataset.options.split(' ').forEach(c=>{PossibleOptions.add(c)})}) // first attempt
// for the start : set only options availables + onchange listener
Selects.forEach(s=>{ // for each Select
s.querySelectorAll('option').forEach(o=>{ // and for each option, in
o.disabled = !PossibleOptions.has(o.value); // is there 1 a result div using this class ?.
if (o.value==='all') o.selected=true; // start the select at position for all
})
s.onchange = SelecChange; // give listener 'change' to function named 'SelecChange'
})
function SelecChange(e) // for every select action...
{
// e.target.value
let // prepare ;
List_Selects = [] // - array for all selects value
, no_FC = true // - flag to know if there is no FS as result
;
PossibleOptions.clear(); // new start
Selects.forEach(s=>{ // make List_Selects
if(s.value!='all') // everything is nothing
{ List_Selects.push(s.value) } // add select value
});
all_FC.forEach(d=>{ // for each FilterContainer <div> as 'd'
let
ok = true,
opt = d.dataset.options.split(' ');
for(let cLS of List_Selects) // for each option choosed in a select
{ ok = ok && opt.includes(cLS) } // check if in class list of the <div>
if (ok){
opt.forEach(c=>{ PossibleOptions.add(c) }); // all the data-options item be added on the set
d.classList.remove('noShow'); // so this div will be shown
no_FC = false; // one is enough
}
else {
d.classList.add('noShow'); // soory guy, your not in the team for this time
}
})
// now we have disable all options witch as no reality in FilterContainer
Selects.forEach(s=>{
s.querySelectorAll('option').forEach(o=>{
o.disabled = !PossibleOptions.has(o.value); // PossibleOptions know
})
})
// last things: is there results ?
if (no_FC) { zeroFC.classList.remove('noShow') } // there is none
else { zeroFC.classList.add('noShow') } // there is one (or more)
}
.noShow { display: none }
<label for="location">Location</label>
<select id="location" class="filterby">
<option value="all">Show All</option>
<option value="australia">Australia</option>
<option value="singapore">Singapore</option>
<option value="newzealand">New Zealand</option>
<option value="usa">USA</option>
<option value="uk">UK</option>
<option value="vietnam">Vietnam</option>
<option value="global">Global</option>
<option value="othercountry">Other</option>
</select>
<label for="type">Type</label>
<select id="type" class="filterby">
<option value="all">Show All</option>
<option value="accommodation">Accommodation</option>
<option value="app">App/Technology</option>
<option value="business">Business</option>
<option value="health">Health</option>
<option value="hospitality">Hospitality</option>
<option value="education">Education</option>
<option value="retail">Retail</option>
<option value="services">Services</option>
<option value="travel">Travel</option>
</select>
<label for="code">Code</label>
<select id="code" class="filterby">
<option value="all">Show All</option>
<option value="001">001</option>
<option value="002">002</option>
<option value="003">003</option>
<option value="004">004</option>
</select>
<hr>
<div id="FilterContainer">
<div class="job-offer-card noresults noShow" data-options="all">
<p>no results</p>
</div>
<div class="job-offer-card" data-options="all vietnam accommodation travel 004">
<p>1 all vietnam accommodation travel _004</p>
</div>
<div class="job-offer-card" data-options="all vietnam travel _003">
<p>2 all vietnam travel _003</p>
</div>
<div class="job-offer-card" data-options="all vietnam accommodation travel">
<p>3 all vietnam accommodation travel</p>
</div>
<div class="job-offer-card" data-options="all australia accommodation travel 003">
<p>4 all australia accommodation travel 003</p>
</div>
<div class="job-offer-card" data-options="all australia education">
<p>5 all australia education</p>
</div>
<div class="job-offer-card" data-options="all vietnam newzealand usa accommodation">
<p>6 all vietnam newzealand usa accommodation</p>
</div>
<div class="job-offer-card" data-options="all vietnam accommodation travel">
<p>7 all vietnam accommodation travel</p>
</div>
<div class="job-offer-card" data-options="all vietnam travel">
<p>8 all vietnam travel</p>
</div>
<div class="job-offer-card" data-options="all vietnam accommodation travel">
<p>9 all vietnam accommodation travel</p>
</div>
<div class="job-offer-card" data-options="all australia accommodation travel">
<p>10 all australia accommodation travel</p>
</div>
<div class="job-offer-card" data-options="all australia health 001">
<p>11 all australia health _001</p>
</div>
<div class="job-offer-card" data-options="all vietnam accommodation 002">
<p>12 all vietnam accommodation _002</p>
</div>
</div>
关于javascript - 如果没有可显示的内容,请禁用选择,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56347314/
在gdb中获取此消息。我知道它不是错误或任何东西。我也做了分页,所以那不是问题。 有什么办法可以抑制此消息? 最佳答案 我很好奇看到这个问题没有得到解决... 我获得了GDB manual,它说(部分
好吧,这很烦人,而且可能很简单。我想用禁用的复选框启动我的网页,并在选择列表框中的特定行后启用这些框。所以我把它放在 onload 方法中 onload = function () { for
看来我需要以某种方式在我的 php 页面上禁用 IPv6,但我不确定该怎么做。我想我必须在我的 INI 文件中的某处添加 --disable-ipv6 ……虽然这看起来不像正确的语法。 我正在尝试解决
我有这两个代码: 第一个是禁用复制粘贴的宏: Sub Desable_Copy() Dim oCtrl As Office.CommandBarControl For Each oCt
在下面的代码中,我想, 如果我选择/单击“患者类型”按钮。它们在菜单“xmenumain”“儿科心电图”项中应该被禁用(它应该列在菜单列表中,但颜色为淡灰色)。我如何实现它? void MyMenu:
我目前在 Coordinator 布局中有一个底部导航栏,我向其添加了 HideBottomViewOnScrollBehaviour。有些屏幕需要隐藏导航栏,我可以通过从 BottomNavigat
我需要一些关于 jquery if 条件的帮助。我已经搜索和测试了几个小时,任何帮助都会很棒!我得到这个 HTML 代码: Value: No Match Test Test 2 Test 3
我正在开发 Delphi -7 中的自定义组件我有一些published特性 private { Private declarations } FFolderzip ,Fi
尝试学习菜单处理的基础知识。我的测试应用程序的菜单栏有 3 个菜单——即“TestApp”、“File”和“Help”。我发现我可以完全删除这些菜单,只需调用 say: NSMenu* rootMen
我以编程方式创建一个 NSMenuItem,但它被禁用。如果我重写 validateMenuItem: 方法并为所有项目返回 YES,则菜单项工作正常。 当我告诉菜单 autoEnableItems
我的 Web 表单中有一个 asp 按钮 (runat="server") 进入更新面板。 当我点击这个按钮时,它会执行一些操作。 Private Sub ButtonDoI
我目前正在为 video.js 构建一个插件,它可以在某些断点处将覆盖层呈现在屏幕上。但是,在不启动视频的情况下,我无法单击任何叠加层。我认为我需要禁用播放器上的点击播放功能。 我应该如何禁用/启用
设置剑道网格 selectable: "row", navigatable: true, 允许选择列标题单元格并通过键盘切换其排序状态。如何完全禁用使用键盘选择列标题单元格的功能? 最
我不想卸载code rush。我只是想在不需要的时候有机会将其关闭。 这可能吗? (快速版本)... 最佳答案 首先您应该打开“DevExpress”菜单。默认情况下,它在 CodeRush Xpre
设置: 我正在使用 TinyMCE 的 Angular 包装器来允许我的用户构建自己的电子邮件模板。这些电子邮件会发送给每个用户组织内的多个人员。我创建了自定义工具栏按钮来插入小文本 block [[
我希望下拉菜单在悬停时打开,前提是窗口大于 767 像素。我试图在页面加载和窗口调整大小时调用一个函数,并使用宽度大小条件。 enableHover() 函数仅适用于页面加载,不适用于窗口调整大小。
由于我遇到了一些问题,我正在 .NET Framework 4 中尝试连接池。使用 SQL Profiler,我可以看到每次从连接池中获取连接时,都会执行存储过程 sp_reset_connectio
我避免在我的 swift 代码中收到警告。然而,当谈到 Storyboard要求时,这对我来说有点困难。 所以现在我只想禁用 xcode 显示有关 Storyboard问题的警告。 我尝试了以下方法但
我不是 JavaScript 专家,我目前正在尝试为表单创建一个函数,该函数根据上一页上选择的数字重复相同的字段。 表单字段可能有 1 到 10 行,每行都有一个单选按钮选择,可启用/禁用每一行。 目
我正在尝试使用 CPU2006 运行各种基准测试,以查看各种优化在 gcc 速度方面的作用。我熟悉 -O1、-O2 和 -O3,但听说 -msse 是一个不错的优化。 -msse 到底是什么?我还看到
我是一名优秀的程序员,十分优秀!