สมมติว่าเรามีอาร์เรย์ของวัตถุเช่นนี้ -
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 } ]