我有一个用这个函数过滤的数组:
function filter(arr, criteria) {
return arr.filter(function(obj) {
return Object.keys(criteria).every(function(c) {
return !(criteria[c]) || obj[c] == criteria[c];
});
});
}
var arr = filter(arr, { dep: dv, arr: av, car: cv, epi: acv, dur: dv });
而且我有一堆选项供用户在 select 中选择。对于持续时间,这是我所拥有的:
<select name="duration" id="duration">
<option selected disabled hidden value="">-</option>
<option value="l1">Less than 1 hour</option>
<option value="1to3">1 to 3 hours</option>
<option value="3to6">3 to 6 hours</option>
<option value="6to10">6 to 10 hours</option>
<option value="m10">More than 10 hours</option>
</select>
但该过滤器基于精确的标准。我想过滤 arr
中介于 1 和 3 或 6 和 10 之间的 float 。我还希望能够运行我在上面看到的其他过滤器,包括 dep、arr、car、epi , 持续时间我有什么办法可以做到这一点吗?
最佳答案
使用array.filter
与回调。下面的代码使用了一个字典,其中的条目对应于选项值。
var myArray = [1,2,3,3.1,Math.PI,4,4.3,6.1]; //sample array
//Dictionary from option values to functions (JS objects work like hashtables)
var options = {
"l1": function(a){return a.duration<1;},
"1to3": function(a){return a.duration>=1 && a.duration<3;},
"3to6": function(a){return a.duration>=3 && a.duration<=6;},
...
//When you need to filter the array, do it like so:
var myNewArray = myArray.filter(
options[ document.getElementById('duration').selectedOptions[0].value ]
);
关于javascript - 如何根据数字范围过滤数组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23945913/