สมมติว่าเรามีอาร์เรย์ของวัตถุเช่นนี้ -
const arr = [
{"firstName":"John", "value": 89},
{"firstName":"Peter", "value": 151},
{"firstName":"Anna", "value": 200},
{"firstName":"Peter", "value": 22},
{"firstName":"Anna","value": 60}
]; เราจำเป็นต้องเขียนฟังก์ชัน JavaScript ที่รับอาร์เรย์ดังกล่าวและรวมคุณสมบัติค่าของอ็อบเจ็กต์ทั้งหมดที่มีค่าใกล้เคียงกันสำหรับคุณสมบัติ firstName
ดังนั้น สำหรับอาร์เรย์ข้างต้น ผลลัพธ์ควรมีลักษณะดังนี้ −
const output = [
{"firstName":"John", "value": 89},
{"firstName":"Peter", "value": 173},
{"firstName":"Anna", "value": 260}
]; สำหรับแต่ละวัตถุ เราจะค้นหาวัตถุที่คล้ายกันซ้ำๆ
(วัตถุที่คล้ายกันสำหรับบริบทของคำถามนี้คือวัตถุที่มีค่า firstName คล้ายกัน)
จากนั้นเราจะเพิ่มคุณสมบัติค่าให้กับวัตถุหนึ่งและลบวัตถุอื่นออกจากอาร์เรย์ สิ่งนี้จะทำจนกว่าเราจะถึงจุดสิ้นสุดของอาร์เรย์ เมื่อไปถึง เราจะลดอาร์เรย์ของเราเป็นอาร์เรย์ที่ต้องการ
ตัวอย่าง
ต่อไปนี้เป็นรหัส -
const arr = [
{"firstName":"John", "value": 89},
{"firstName":"Peter", "value": 151},
{"firstName":"Anna", "value": 200},
{"firstName":"Peter", "value": 22},
{"firstName":"Anna","value": 60}
];
const sumSimilar = arr => {
const res = [];
for(let i = 0; i < arr.length; i++){
const ind = res.findIndex(el => el.firstName === arr[i].firstName);
if(ind === -1){
res.push(arr[i]);
}else{
res[ind].value += arr[i].value;
};
};
return res;
};
console.log(sumSimilar(arr)); ผลลัพธ์
สิ่งนี้จะสร้างผลลัพธ์ต่อไปนี้ในคอนโซล -
[
{ firstName: 'John', value: 89 },
{ firstName: 'Peter', value: 173 },
{ firstName: 'Anna', value: 260 }
]