Bagaimana untuk Mencari Elemen Padanan Merentasi Pelbagai Tatasusunan JavaScript?

Patricia Arquette
Lepaskan: 2024-10-24 18:45:09
asal
803 orang telah melayarinya

How to Find Matching Elements Across Multiple JavaScript Arrays?

Elemen Memadankan Merentas Berbilang Tatasusunan JavaScript

Masalah

Memandangkan pelbagai tatasusunan JavaScript nilai rentetan, cari elemen yang berlaku sama dalam semua tatasusunan. Contohnya:

<code class="javascript">var arr1 = ['apple', 'orange', 'banana', 'pear', 'fish', 'pancake', 'taco', 'pizza'];
var arr2 = ['taco', 'fish', 'apple', 'pizza'];
var arr3 = ['banana', 'pizza', 'fish', 'apple'];</code>
Salin selepas log masuk

Output yang dijangkakan:

<code class="javascript">['apple', 'fish', 'pizza']</code>
Salin selepas log masuk

Penyelesaian

Untuk mencari elemen padanan, kita boleh menggunakan gabungan kaedah Tatasusunan:

<code class="javascript">const arrays = [arr1, arr2, arr3];
const result = arrays.shift().filter((v) => {
  return arrays.every((a) => {
    return a.indexOf(v) !== -1;
  });
});</code>
Salin selepas log masuk

Langkah:

  1. Gunakan arrays.shift() untuk mengalih keluar tatasusunan pertama daripada senarai asal.
  2. Gunakan .filter() pada tatasusunan pertama untuk menggelung melalui setiap elemen v.
  3. Gunakan .every() pada tatasusunan yang lain untuk menyemak sama ada setiap satu mengandungi elemen semasa v.
  4. Jika elemen v hadir dalam setiap tatasusunan, masukkannya dalam tatasusunan hasil.

Dengan menggunakan logik ini secara berulang pada setiap tatasusunan, kita boleh mencari unsur-unsur yang berlaku secara serupa dalam semua tatasusunan yang disediakan.

Pertimbangan Tambahan

Pengendalian Elemen Pendua:

Penyelesaian yang disediakan mengandaikan bahawa tatasusunan tidak mengandungi unsur pendua. Jika mereka berbuat demikian, anda boleh mengubah suai kod seperti berikut:

<code class="javascript">const result = arrays.shift().reduce((res, v) => {
  if (res.indexOf(v) === -1 &amp;&amp; arrays.every((a) => {
    return a.indexOf(v) !== -1;
  })) res.push(v);
  return res;
}, []);</code>
Salin selepas log masuk

Kod ini menggunakan .reduce() dan bukannya .filter(). Ia menyemak pendua dalam tatasusunan hasil dan hanya menambah elemen unik yang terdapat dalam setiap tatasusunan.

Bilangan Arbitrari Tatasusunan:

Penyelesaian direka bentuk untuk berfungsi dengan bilangan tatasusunan yang tidak diketahui. Dengan menggunakan arrays.shift(), kita boleh membandingkan tatasusunan pertama secara berurutan dengan tatasusunan yang tinggal sehingga semua tatasusunan telah diproses.

Atas ialah kandungan terperinci Bagaimana untuk Mencari Elemen Padanan Merentasi Pelbagai Tatasusunan 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
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!