cari
Rumahhujung hadapan webtutorial jsBagaimana untuk Menggabungkan Kunci Pendua dan Menjumlahkan Nilainya dalam Tatasusunan Objek JavaScript?

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 },
];

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 },
];

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);

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!

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
Ganti aksara rentetan dalam javascriptGanti aksara rentetan dalam javascriptMar 11, 2025 am 12:07 AM

Penjelasan terperinci mengenai kaedah penggantian rentetan javascript dan Soalan Lazim Artikel ini akan meneroka dua cara untuk menggantikan watak rentetan dalam JavaScript: Kod JavaScript dalaman dan HTML dalaman untuk laman web. Ganti rentetan di dalam kod JavaScript Cara yang paling langsung ialah menggunakan kaedah pengganti (): str = str.replace ("cari", "ganti"); Kaedah ini hanya menggantikan perlawanan pertama. Untuk menggantikan semua perlawanan, gunakan ungkapan biasa dan tambahkan bendera global g: str = str.replace (/fi

Tutorial Persediaan API Carian Google CustomTutorial Persediaan API Carian Google CustomMar 04, 2025 am 01:06 AM

Tutorial ini menunjukkan kepada anda bagaimana untuk mengintegrasikan API carian Google tersuai ke dalam blog atau laman web anda, menawarkan pengalaman carian yang lebih halus daripada fungsi carian tema WordPress standard. Ia menghairankan mudah! Anda akan dapat menyekat carian ke y

Bina Aplikasi Web Ajax anda sendiriBina Aplikasi Web Ajax anda sendiriMar 09, 2025 am 12:11 AM

Jadi di sini anda, bersedia untuk mempelajari semua perkara ini yang dipanggil Ajax. Tetapi, apa sebenarnya? Istilah Ajax merujuk kepada kumpulan teknologi longgar yang digunakan untuk membuat kandungan web yang dinamik dan interaktif. Istilah Ajax, yang asalnya dicipta oleh Jesse J

Contoh warna json failContoh warna json failMar 03, 2025 am 12:35 AM

Siri artikel ini ditulis semula pada pertengahan 2017 dengan maklumat terkini dan contoh segar. Dalam contoh JSON ini, kita akan melihat bagaimana kita dapat menyimpan nilai mudah dalam fail menggunakan format JSON. Menggunakan notasi pasangan nilai utama, kami boleh menyimpan apa-apa jenis

10 JQuery Syntax Highlighters10 JQuery Syntax HighlightersMar 02, 2025 am 12:32 AM

Tingkatkan Penyampaian Kod Anda: 10 Penyeret Sintaks untuk Pemaju Coretan kod perkongsian di laman web atau blog anda adalah amalan biasa bagi pemaju. Memilih penyapu sintaks yang betul dapat meningkatkan daya tarikan dan daya tarikan visual dengan ketara. T

8 plugin susun atur halaman jquery yang menakjubkan8 plugin susun atur halaman jquery yang menakjubkanMar 06, 2025 am 12:48 AM

Leverage JQuery untuk Layouts Laman Web yang mudah: 8 Plugin Essential JQuery memudahkan susun atur laman web dengan ketara. Artikel ini menyoroti lapan plugin jQuery yang kuat yang menyelaraskan proses, terutamanya berguna untuk penciptaan laman web manual

10 JavaScript & JQuery MVC Tutorial10 JavaScript & JQuery MVC TutorialMar 02, 2025 am 01:16 AM

Artikel ini membentangkan pemilihan lebih daripada 10 tutorial mengenai rangka kerja javascript dan jquery model-view-controller (MVC), sesuai untuk meningkatkan kemahiran pembangunan web anda pada tahun baru. Tutorial ini merangkumi pelbagai topik, dari Foundatio

Apa itu ' ini ' Dalam JavaScript?Apa itu ' ini ' Dalam JavaScript?Mar 04, 2025 am 01:15 AM

Mata teras Ini dalam JavaScript biasanya merujuk kepada objek yang "memiliki" kaedah, tetapi ia bergantung kepada bagaimana fungsi dipanggil. Apabila tidak ada objek semasa, ini merujuk kepada objek global. Dalam penyemak imbas web, ia diwakili oleh tetingkap. Apabila memanggil fungsi, ini mengekalkan objek global; tetapi apabila memanggil pembina objek atau mana -mana kaedahnya, ini merujuk kepada contoh objek. Anda boleh mengubah konteks ini menggunakan kaedah seperti panggilan (), memohon (), dan mengikat (). Kaedah ini memanggil fungsi menggunakan nilai dan parameter yang diberikan. JavaScript adalah bahasa pengaturcaraan yang sangat baik. Beberapa tahun yang lalu, ayat ini

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

MinGW - GNU Minimalis untuk Windows

MinGW - GNU Minimalis untuk Windows

Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual