const cards = [
{gaps: ["science", "education"]},
{gaps: ["weapon"]},
{gaps: ["figures", "character"]},
{gaps: ["figures", "education"]},
]
function filter({})
请帮助,在调用filter ()时有一个数组,这应该会将5个组返回到控制台
education
enter code here
教育”}}、{差距:“数字”、“教育”}--“武器”}-武器
发布于 2021-11-08 20:12:38
使用Array#reduce
,在cards
上迭代,同时更新一个Map
,其中key
是gap,而value
是其间隙数组中具有此间隙的对象的列表。
在每次迭代中,您将使用gaps
迭代Array#forEach
并更新地图:
const cards = [ {gaps: ["science", "education"]}, {gaps: ["weapon"]}, {gaps: ["figures", "character"]}, {gaps: ["figures", "education"]} ];
const gapsMap = cards.reduce((map, { gaps = [] }) => {
gaps.forEach(gap => map.set(gap, [...(map.get(gap) || []), {gaps: [...gaps]}]));
return map;
}, new Map);
console.log([...gapsMap]);
console.log(gapsMap.get("education"));
https://stackoverflow.com/questions/69889248
复制相似问题