使用 Jquery Each 在 Javascript 对象和数组中查找匹配项
Posted
技术标签:
【中文标题】使用 Jquery Each 在 Javascript 对象和数组中查找匹配项【英文标题】:Find Match in Javascript Object and Array using Jquery Each 【发布时间】:2018-04-05 14:49:32 【问题描述】:尝试使用过滤器数组来搜索商店位置的 javascript 对象,我需要使用过滤器数组中的两个过滤器获得完全匹配,该数组现在有 2 个项目,但会有更多。下面的代码有效,但它正在为每个商店查找匹配项。由于 .json 文件中的一个商店没有 ATM 机,因此不应出现在控制台中。任何帮助将不胜感激!
.json:
[
"storenumber": "5210",
"services": [
"img": "/locator/img/icons/atm.svg",
"alt": "ATM Machine"
,
"img": "/locator/img/icons/carwash.svg",
"alt": "Car Wash"
]
,
"storenumber": "1066",
"services": [
"img": "/locator/img/icons/carwash.svg",
"alt": "Car Wash"
]
]
.js:
var jsonData,
filteredJsonData = [],
filters = ["Car Wash","ATM Machine"];
$.getJSON("/locator/js/locations.json")
.done(function(data)
jsonData = data;
$.each(jsonData,function(locationsIndex,locationsItem)
var services = locationsItem.services;
$.each(services,function(servicesIndex,servicesItem)
if (servicesItem.alt && ($.inArray(servicesItem.alt,filters) != -1))
// This is finding matches in the filters array, but i need to match all items in the array
console.log("Match Found: " + servicesItem.alt + " at Index " + locationsIndex)
filteredJsonData.push(locationsItem)
)
)
console.log(filteredJsonData)
)
【问题讨论】:
在将它们包含在最终结果中之前,您是否应该考虑所有过滤器结果并找到所有过滤器都存在的结果?只要它们通过任何单个过滤器,听起来您就可以将它们添加到最终结果中。 考虑使用每个 (developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/…) 来确定被过滤的元素是否与所有过滤器匹配。 为什么我的投票被否决了,我在网站上研究了一个上午的这个问题,终于崩溃了并寻求帮助。 【参考方案1】:您可以使用filter
、some
和Set
的组合:
const jsonData = ["storenumber": "5210","services": [ "img": "/locator/img/icons/atm.svg","alt": "ATM Machine","img": "/locator/img/icons/carwash.svg","alt": "Car Wash"], "storenumber": "1066","services": ["img": "/locator/img/icons/carwash.svg","alt": "Car Wash"]],
filters = ["Car Wash","ATM Machine"];
const locations = jsonData.filter( location =>
const filterSet = new Set(filters);
return location.services.some( service =>
filterSet.delete(service.alt);
return !filterSet.size;
);
);
console.log(locations);
.as-console-wrapper max-height: 100% !important; top: 0;
注意:我删除 Ajax 调用只是为了演示 sn-p。
对于旧版浏览器
一个适用于旧浏览器(ES3,主要是 IE)的版本,使用 jQuery:
var jsonData = ["storenumber": "5210","services": [ "img": "/locator/img/icons/atm.svg","alt": "ATM Machine","img": "/locator/img/icons/carwash.svg","alt": "Car Wash"], "storenumber": "1066","services": ["img": "/locator/img/icons/carwash.svg","alt": "Car Wash"]],
filters = ["Car Wash","ATM Machine"];
var locations = $.grep(jsonData, function (location)
var filterSet = ;
for (var i = 0; i < filters.length; i++)
filterSet[filters[i]] = 1;
var filtersLeft = filters.length;
$.each(location.services, function (i, service)
if (filterSet[service.alt])
filtersLeft--;
filterSet[service.alt] = 0;
;
return filtersLeft > 0;
);
return filtersLeft === 0;
);
console.log(locations);
.as-console-wrapper max-height: 100% !important; top: 0;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
【讨论】:
有效!它会在 IE9 中运行吗? 我添加了一个可以在旧浏览器上运行的版本。 有效!我整天都在沮丧地研究这个问题,这是一些可靠的帮助。你先生是个传奇。以上是关于使用 Jquery Each 在 Javascript 对象和数组中查找匹配项的主要内容,如果未能解决你的问题,请参考以下文章