Rumah >hujung hadapan web >tutorial js >Bagaimana Menjumlahkan Nilai Kunci Pendua dalam Tatasusunan Objek JavaScript?

Bagaimana Menjumlahkan Nilai Kunci Pendua dalam Tatasusunan Objek JavaScript?

Linda Hamilton
Linda Hamiltonasal
2024-12-17 07:41:24435semak imbas

How to Sum Values of Duplicate Keys in a JavaScript Array of Objects?

Menggabungkan Nilai Harta Kunci Sama dalam Susunan Objek

Memandangkan tatasusunan objek JavaScript seperti di bawah, bagaimana kita boleh menggabungkan kunci pendua dengan menjumlahkan nilai yang sepadan?

objArr = [
    {key:"Mon Sep 23 2013 00:00:00 GMT-0400", val:42},
    {key:"Mon Sep 24 2013 00:00:00 GMT-0400", val:78},
    {key:"Mon Sep 25 2013 00:00:00 GMT-0400", val:23},
    {key:&quot;Mon Sep 23 2013 00:00:00 GMT-0400&quot;, val:54} // <- duplicate key
]

Matlamat kami adalah untuk mendapatkan tatasusunan dengan kunci unik dan nilai hasil penjumlahan, seperti ini:

reducedObjArr = [
    {key:&quot;Mon Sep 23 2013 00:00:00 GMT-0400&quot;, val:96},
    {key:&quot;Mon Sep 24 2013 00:00:00 GMT-0400&quot;, val:78},
    {key:&quot;Mon Sep 25 2013 00:00:00 GMT-0400&quot;, val:23}
]

Penyelesaian Menggunakan Peta dan Kurangkan

Daripada mengulang dan menolak nilai, kita boleh menggunakan yang berkuasa gabungan peta dan mengurangkan:

const objArr = [
  {key: 'Mon Sep 23 2013 00:00:00 GMT-0400', val: 42},
  {key: 'Mon Sep 24 2013 00:00:00 GMT-0400', val: 78},
  {key: 'Mon Sep 25 2013 00:00:00 GMT-0400', val: 23},
  {key: 'Mon Sep 23 2013 00:00:00 GMT-0400', val: 54} // <- duplicate key
];

// Convert data into a Map with reduce
const counts = objArr.reduce((prev, curr) => {
  const count = prev.get(curr.key) || 0;
  prev.set(curr.key, curr.val + count);
  return prev;
}, new Map());

// Map counts object back to an array
const reducedObjArr = [...counts].map(([key, value]) => {
  return {key, value}
});

console.log(reducedObjArr); 

Pendekatan ini secara berkesan mengagregatkan dan menggabungkan nilai dengan nilai yang sama kekunci, menghasilkan tatasusunan yang dikurangkan.

Atas ialah kandungan terperinci Bagaimana Menjumlahkan Nilai Kunci Pendua dalam Tatasusunan Objek JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn