Rumah > hujung hadapan web > tutorial js > Bagaimana untuk Menggabungkan Kunci Pendua dan Menjumlahkan Nilainya dalam Tatasusunan Objek JavaScript?

Bagaimana untuk Menggabungkan Kunci Pendua dan Menjumlahkan Nilainya dalam Tatasusunan Objek JavaScript?

Linda Hamilton
Lepaskan: 2024-11-28 03:47:10
asal
829 orang telah melayarinya

How to Merge Duplicate Keys and Sum Their Values in a JavaScript Object Array?

Menggabungkan Kunci Pendua dan Menjumlahkan Nilai dalam Tatasusunan Objek

Dalam JavaScript, bekerja dengan tatasusunan objek boleh menjadi perkara biasa. Kadangkala, kita mungkin menghadapi keperluan untuk mengumpulkan dan mengubah suai objek dalam tatasusunan sambil mengekalkan sifat tertentu. Satu senario sedemikian melibatkan menjumlahkan nilai yang dikaitkan dengan kekunci yang serupa.

Mari kita terokai tugas ini dengan tatasusunan contoh objek:

const objects = [
  { name: 'P1', value: 150 },
  { name: 'P1', value: 150 },
  { name: 'P2', value: 200 },
  { name: 'P3', value: 450 },
];
Salin selepas log masuk

Matlamat kami adalah untuk mengumpulkan objek mengikut sifat 'nama' dan jumlahkan sifat 'nilai' untuk setiap 'nama' yang berbeza. Output yang diingini sepatutnya kelihatan seperti ini:

[
  { name: 'P1', value: 300 },
  { name: 'P2', value: 200 },
  { name: 'P3', value: 450 },
];
Salin selepas log masuk

Untuk mencapai ini, kami boleh menggunakan keupayaan manipulasi objek dan tatasusunan JavaScript. Berikut ialah penyelesaian langkah demi langkah:

1. Cipta Objek untuk Menyimpan Nilai Summed

Mulakan dengan mencipta objek JavaScript kosong yang dipanggil 'pemegang' yang akan berfungsi sebagai bekas untuk menyimpan nilai hasil penjumlahan bagi setiap 'nama'.

2. Lelaran ke atas Tatasusunan Input

Gunakan gelung 'forEach' untuk lelaran ke atas setiap objek dalam tatasusunan input ('objek').

3. Semak Nama Sedia Ada dalam 'pemegang'

Di dalam gelung, semak sama ada sifat 'nama' objek semasa sudah wujud sebagai harta dalam objek 'pemegang' menggunakan 'hasOwnProperty(d.name)'.

4. Jumlahkan atau Nilai Permulaan

Jika sifat 'nama' wujud, tambahkan sifat 'nilai' objek semasa kepada harta yang sepadan dalam 'pemegang' (cth., 'pemegang[d.nama] = d.nilai '). Jika sifat 'name' tidak ditemui, mulakan ia dengan sifat 'value' bagi objek semasa ('holder[d.name] = d.value').

5. Cipta Tatasusunan Baharu dengan Objek Gabungan

Setelah semua nilai dijumlahkan, cipta tatasusunan kosong baharu yang dipanggil 'obj2' untuk menyimpan objek yang digabungkan.

6. Lelaran ke atas 'pemegang' dan Tekan Objek Bercantum

Gunakan gelung lain untuk mengulangi sifat objek 'pemegang' ('untuk (var prop dalam pemegang)'). Untuk setiap sifat, cipta objek baharu dengan sifat 'nama' dan 'nilai' dan tolaknya ke dalam 'obj2'.

7. Log Output

Akhir sekali, log tatasusunan 'obj2' ke konsol untuk melihat objek yang digabungkan dengan sifat 'nilai' hasil penjumlahan.

Kod Contoh

Berikut ialah coretan kod yang menunjukkan penyelesaian:

const objects = [
  { name: 'P1', value: 150 },
  { name: 'P1', value: 150 },
  { name: 'P2', value: 200 },
  { name: 'P3', value: 450 },
];

const holder = {};

objects.forEach(d => {
  if (holder.hasOwnProperty(d.name)) {
    holder[d.name] += d.value;
  } else {
    holder[d.name] = d.value;
  }
});

const obj2 = [];

for (var prop in holder) {
  obj2.push({ name: prop, value: holder[prop] });
}

console.log(obj2);
Salin selepas log masuk

Dengan mengikuti langkah-langkah ini, anda boleh mengumpulkan dengan berkesan dan nilai jumlah yang dikaitkan dengan kunci serupa dalam tatasusunan objek, mencipta tatasusunan baharu dengan objek yang diubah suai mengikut output yang diingini.

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

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan