首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >简化javascript函数中的嵌套循环

简化javascript函数中的嵌套循环
EN

Stack Overflow用户
提问于 2022-06-28 03:07:46
回答 3查看 60关注 0票数 0

我在JS中有这个功能

代码语言:javascript
复制
function getMap(objectList) {
  const objectMap = new Map();
  IDS.foreach(id => {
    const attribute = objectList.find(object => object.getId() === id);
    if (attribute) {
      objectMap.set(id, attribute);
    } else {
      objectMap.set(id, null);
    }
}

这是一个嵌套循环,因为for循环中有查找。如何简化呢?如果嵌套循环不能简化,其他部分可以简化吗?

EN

回答 3

Stack Overflow用户

发布于 2022-06-28 03:11:38

假设对象is是唯一的,那么看起来您真正需要做的就是预先对每个对象调用getId。如果您愿意,可以使用条件运算符代替if/else

代码语言:javascript
复制
function getMap(objectList) {
    const objectsById = new Map(
        objectList.map(object => [object.getId(), object])
    );
    const objectMap = new Map();
    for (const id of IDS) {
        objectMap.set(id, objectsById.get(id) || null);
    }
}
票数 0
EN

Stack Overflow用户

发布于 2022-06-28 03:19:38

您可以为每个ID创建一个带有null条目的数组,然后是在objectList中实际有值的条目,并将该数组传递给Map构造函数:

代码语言:javascript
复制
function getMap(objectList) {
  return new Map([
    ...IDs.map(id => [id, null]),
    ...objectList.map(object => [object.getId(), object])
  ]);
}
票数 0
EN

Stack Overflow用户

发布于 2022-06-28 04:04:24

通过简单的回调使用本机代码

代码语言:javascript
复制
const result = (IDS || []).map(function(id, idx, arr) {
    const pos = (objectList || []).findIndex(object => object.getId() === id);
    const output = [];
    output[id] = (pos >= 0 ? objectList[pos] : null);
    return output;
});

希望这能帮上忙。;D

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72780332

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档