查找对象数组是否包含其中一个标记的最快方法
Fastest way to find if an array of object contains one of the tags
我有一个对象数组,每个对象都包含一个属性tags
,该属性包含一个字符串数组
let item = {
tags: [String],
name: String
};
let queue = [item1, item2, ...];
我想知道查找包含特定tag(s)
的所有项目。对于循环,蛮力为2:
function findTags(tags) {
let results = [];
queue.forEach(function (item) {
tags.forEach(function (tag) {
if (item.tags.indexOf(tag) !== -1) {
results.push(item);
}
});
});
return results;
}
有比O(N^2)
更好的方法吗?
使用Set
或仅使用Object
来存储标记,这样就不需要迭代标记数组来搜索标记。
使用Array#some
在找到匹配项后立即停止迭代。
由于您正在筛选阵列,请使用Array#filter
var tagsObj = Object.create(null);
tags.forEach(function (tag) {
tagsObj[tag] = true;
});
return queue.filter(function (item) {
return item.tags.some(function (tag) {
return tagsObj[tag];
});
});
我想为getFirst
和getAll
函数实现一个。
var queue = [
{
tags: ["tag01","tag02","tag03"],
name: "name01"
},
{
tags: ["tag04","tag05","tag06"],
name: "name02"
},
{
tags: ["tag02","tag04","tag06"],
name: "name03"
},
{
tags: ["tag01","tag03","tag05"],
name: "name04"
},
],
getFirst = (...tags) => queue.find( o => tags.some( t => o.tags.includes(t))),
getAll = (...tags) => queue.reduce((p,o) => tags.some( t => o.tags.includes(t)) ? p.concat(o) : p ,[]);
document.write("<pre> Result for getFirst:'n" + JSON.stringify(getFirst("tag04","tag02"),null,2) + "</pre>");
document.write("<pre> Result for getAll:'n" + JSON.stringify(getAll("tag04","tag02"),null,2) + "</pre>");
相关文章:
- 将一个方法转换为promise:Nodejs
- 如何在所有ng点击事件AngularJS上启动一个方法
- 创建一个方法,通过一个窗口进行迭代并获取Titanium中的所有控件
- 如何创建一个方法来验证数组的范围
- 如何将一个方法延迟到另一个方法首先完成,javascript
- 在Javascript中对类的每个实例调用一个方法
- 如何重写一个方法,并且仍然能够在重写的方法中使用基方法
- NodeJS-从同一文件中的另一个方法调用一个方法
- 有没有任何情况下,一个方法不应该是原型方法
- Jasmine间谍的函数称为一个方法
- 在带有参数列表的表单submit上调用一个方法
- 方法不在另一个方法内部调用
- 在 1 个方法中增加变量值会触发另一个方法的 for 循环,欢迎任何建议
- 如何使用javascript express node将变量从控制器中的一个方法公开.js到另一个控制器.js
- 如何在javascript中将变量的值分配给另一个方法
- 在浏览器关闭时,单击确认对话框中的“停留在页面上”,执行一个方法
- 使用一个方法在c#中启动其他方法
- 如何在Ember中转换到另一个路由时调用一个方法
- 在typescript中重载一个方法
- 我可以在setInterval函数中放入一个方法作为参数吗