我在JS中有这个功能
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循环中有查找。如何简化呢?如果嵌套循环不能简化,其他部分可以简化吗?
发布于 2022-06-28 03:11:38
假设对象is是唯一的,那么看起来您真正需要做的就是预先对每个对象调用getId。如果您愿意,可以使用条件运算符代替if/else。
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);
}
}发布于 2022-06-28 03:19:38
您可以为每个ID创建一个带有null条目的数组,然后是在objectList中实际有值的条目,并将该数组传递给Map构造函数:
function getMap(objectList) {
return new Map([
...IDs.map(id => [id, null]),
...objectList.map(object => [object.getId(), object])
]);
}发布于 2022-06-28 04:04:24
通过简单的回调使用本机代码
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
https://stackoverflow.com/questions/72780332
复制相似问题