Jadual Kandungan
Pengenalan
Senario masalah dan struktur data
Analisis salah faham yang biasa
Penyelesaian: Gunakan penapis (), beberapa (), setiap () gabungan
Kod parsing
Nota dan amalan terbaik
Meringkaskan
Rumah hujung hadapan web tutorial js Panduan untuk menapis susunan objek bersarang secara efisien berdasarkan keadaan kompleks dalam javascript

Panduan untuk menapis susunan objek bersarang secara efisien berdasarkan keadaan kompleks dalam javascript

Oct 01, 2025 am 07:48 AM

Panduan untuk menapis susunan objek bersarang secara efisien berdasarkan keadaan kompleks dalam javascript

Tutorial ini akan menyelam cara menggunakan penapis (), beberapa (), dan setiap () kaedah dalam JavaScript untuk menapis dengan cekap satu lagi pilihan objek bersarang berdasarkan set susunan bersyarat kompleks. Kami akan menggunakan kes sebenar untuk menganalisis secara terperinci bagaimana untuk membina logik untuk mencapai penapisan data yang tepat, memastikan bahawa hanya item yang sepadan dengan semua syarat yang ditentukan dikekalkan.

Pengenalan

Dalam pembangunan web moden, pemprosesan dan penapisan struktur data kompleks adalah tugas yang sama. Terutama apabila data wujud dalam bentuk tatasusunan objek bersarang dan keadaan penapisan adalah sama rumit, bagaimana menulis kod yang efisien dan mudah dibaca menjadi cabaran. Tutorial ini akan memberi tumpuan kepada senario tipikal: Penapisan pelbagai data utama berdasarkan pelbagai objek yang mengandungi beberapa sub-kondisi, di mana setiap elemen array data primer juga mengandungi pelbagai objek pilihan. Kami akan menggunakan penapis fungsi pesanan tinggi JavaScript yang kuat (), beberapa () dan setiap () untuk menyelesaikan masalah ini dengan anggun.

Senario masalah dan struktur data

Katakan kami mempunyai pelbagai produk, setiap objek produk mengandungi pelbagai pilihan, yang menggambarkan pelbagai sifat produk (seperti saiz, warna). Pada masa yang sama, kami juga mempunyai pelbagai keadaan yang mentakrifkan syarat -syarat yang mesti kita temui untuk produk yang kita mahu menapis. Setiap keadaan itu sendiri juga merupakan array yang mengandungi pelbagai atribut/pasangan nilai, menunjukkan bahawa produk perlu memenuhi atribut ini pada masa yang sama sebelum ia dapat dipilih.

Contoh data asal:

 produk const = [
  {
    Pilihan: [
       {id: 1, nama: 'saiz', nilai: '10'},
       {id: 2, nama: 'warna', nilai: 'kuning'},
    ],
  },
  {
    Pilihan: [
       {id: 1, nama: 'saiz', nilai: '20'},
       {id: 2, nama: 'warna', nilai: 'kuning'},
    ],
  },
  {
    Pilihan: [
      {id: 1, nama: 'saiz', nilai: '10'},
      {id: 2, nama: 'warna', nilai: 'merah jambu'},
    ],
  },
  { 
    Pilihan: [
      {id: 1, nama: 'saiz', nilai: '20'},
      {id: 2, nama: 'warna', nilai: 'merah jambu'}
    ],
  },
  {
    Pilihan: [
      {id: 1, nama: 'saiz', nilai: '39'},
      {id: 2, nama: 'warna', nilai: 'merah jambu'},
    ],
   },
];

Contoh kriteria penapis:

 syarat const = [
  [
    {name: 'saiz', nilai: '10'},
    {name: 'color', value: 'yellow'},
  ],
  [
    {name: 'saiz', nilai: '10'},
    {Nama: 'Warna', Nilai: 'Pink'},
  ],
];

Matlamat kami adalah untuk menyaring semua produk yang memenuhi sebarang array bersyarat. Sebagai contoh, jika produk memenuhi kedua -dua "saiz 10 dan warna kuning" atau "saiz 10 dan warna merah jambu" pada masa yang sama, produk harus dimasukkan ke dalam hasilnya.

Output yang dijangkakan:

 const outputProducts = [
  {
    Pilihan: [
      {id: 1, nama: 'saiz', nilai: '10'},
      {id: 2, nama: 'warna', nilai: 'kuning'},
    ],
  },
  {
    Pilihan: [
      {id: 1, nama: 'saiz', nilai: '10'},
      {id: 2: 'warna', nilai: 'merah jambu'},
    ],
  },
];

Analisis salah faham yang biasa

Apabila cuba menyelesaikan masalah sedemikian, kesilapan biasa bagi pemula adalah mengelirukan beberapa () dan setiap () senario yang berkenaan, atau gagal untuk memadankan logik dengan betul dalam gelung bersarang. Sebagai contoh, kod tentatif berikut, walaupun menggunakan penapis, cari dan setiap, gagal mencapai hasil yang diharapkan:

 const filterProducts = products.filter ((el) => {
   kembali el.options.find ((o) => {// Pilihan Produk Traversal Return Conditions.Find ((m) => {// Traversal Condition Groups // Logic di sini adalah salah: ia cuba membuat pilihan produk `o` memadankan semua subkondisi dalam keseluruhan kumpulan keadaan` m`.
       // Malah, kita harus memeriksa sama ada semua pilihan `el.Options` produk memenuhi semua subkondisi dalam kumpulan keadaan` m`.
       kembali m.every (({name, value}) => o.name == name && o.value === value);
     });
   });
 });

Kesalahan kod di atas ialah apa yang diharapkan secara dalaman oleh M.Every (...) adalah untuk memeriksa sama ada setiap subkondisi dalam array M dipenuhi oleh O (pilihan produk tunggal). Walau bagaimanapun, pilihan produk o biasanya mewakili hanya satu atribut (seperti saiz atau warna), dan mustahil untuk memenuhi semua sub-kondisi dalam kumpulan keadaan M pada masa yang sama (mis., O tidak boleh kedua-dua saiz: '10' dan warna: 'kuning'). Logik yang betul adalah untuk setiap subkondisi dalam kumpulan keadaan M, kita perlu menyemak sama ada terdapat pilihan yang sepadan dalam pelbagai pilihan produk semasa.

Penyelesaian: Gunakan penapis (), beberapa (), setiap () gabungan

Kunci untuk menyelesaikan masalah ini adalah dengan betul penapis sarang (), beberapa (), dan setiap () untuk membina aliran logik yang tepat.

  1. Penapis () : Lapisan paling luar, digunakan untuk melintasi pelbagai produk dan menapis produk individu yang memenuhi kriteria.
  2. Sesetengah () (lapisan pertama dalaman) : melintasi pelbagai keadaan. Bagi setiap produk, kita perlu menyemak sama ada ia memenuhi mana -mana kumpulan keadaan dalam pelbagai syarat. Selagi kumpulan keadaan dipenuhi, produk harus dikekalkan.
  3. setiap () (lapisan kedua dalaman) : melangkah ke atas keadaan yang dipilih sekarang (kumpulan keadaan, contohnya [{name: 'saiz', nilai: '10'}, {name: 'color', value: 'yellow'}]). Untuk setiap subkondisi dalam kumpulan keadaan ini (mis. {Nama: 'Saiz', nilai: '10'}), produk mesti memuaskannya.
  4. Sesetengah () (lapisan ketiga dalaman) : melangkah ke atas pelbagai pilihan produk semasa. Bagi setiap subkondisi dalam setiap (), kita perlu menyemak sama ada sekurang -kurangnya satu pilihan dalam pilihan produk yang sepadan dengannya.

Kod Penyelesaian Lengkap:

 produk const = [
  {
    Pilihan: [
       {id: 1, nama: 'saiz', nilai: '10'},
       {id: 2, nama: 'warna', nilai: 'kuning'},
    ],
  },
  {
    Pilihan: [
       {id: 1, nama: 'saiz', nilai: '20'},
       {id: 2, nama: 'warna', nilai: 'kuning'},
    ],
  },
  {
    Pilihan: [
      {id: 1, nama: 'saiz', nilai: '10'},
      {id: 2, nama: 'warna', nilai: 'merah jambu'},
    ],
  },
  { 
    Pilihan: [
      {id: 1, nama: 'saiz', nilai: '20'},
      {id: 2, nama: 'warna', nilai: 'merah jambu'}
    ],
  },
  {
    Pilihan: [
      {id: 1, nama: 'saiz', nilai: '39'},
      {id: 2, nama: 'warna', nilai: 'merah jambu'},
    ],
   },
];

syarat const = [
  [
    {name: 'saiz', nilai: '10'},
    {name: 'color', value: 'yellow'},
  ],
  [
    {name: 'saiz', nilai: '10'},
    {Nama: 'Warna', Nilai: 'Pink'},
  ],
];

const filterProducts = products.filter (Product =>
  // 1. Bagi setiap produk, periksa sama ada ia memenuhi mana -mana kumpulan keadaan dalam keadaan array 'syarat' (keadaan =>
    // 2. Untuk keadaan 'keadaan' keadaan semasa, periksa sama ada semua subkondisinya berpuas hati dengan keadaan produk.every (({name, value}) =>
      // 3. Bagi setiap subkondisi dalam 'keadaan' (seperti {name: 'saiz', nilai: '10'}),
      // Periksa sama ada terdapat pilihan yang sepadan dalam pelbagai 'Pilihan' produk produk semasa.options.some (option => option.name === name && option.value === Value)
    )
  )
);

Console.log (FilterProducts);
/*
Hasil output:
[
  {
    Pilihan: [
      {id: 1, nama: 'saiz', nilai: '10'},
      {id: 2, nama: 'warna', nilai: 'kuning'}
    ]
  },
  {
    Pilihan: [
      {id: 1, nama: 'saiz', nilai: '10'},
      {id: 2, nama: 'warna', nilai: 'merah jambu'}
    ]
  }
]
*/

Kod parsing

  • Products.Filter (Product => ...) : Ini adalah titik permulaan keseluruhan operasi penapisan. Ia melangkah ke atas setiap objek produk dalam pelbagai produk. Jika fungsi tanpa nama dalaman kembali benar, produk akan dimasukkan ke dalam array hasil FilterProducts.
  • Conditions.Some (Condition => ...) : Untuk produk semasa, kami menyemak pelbagai syarat. Kaedah beberapa () akan melelehkan setiap keadaan dalam keadaan (iaitu, kumpulan keadaan). Selagi fungsi panggilan balik dalaman kumpulan keadaan kembali benar, sesetengah () akan segera kembali benar, menunjukkan bahawa produk semasa memenuhi sekurang -kurangnya satu kumpulan keadaan dan dikekalkan oleh penapis.
  • Condition.every (({name, value}) => ...) : Apabila beberapa () melintasi kumpulan keadaan, kaedah setiap () memeriksa semua subkondisi dalam kumpulan keadaan ini (dapatkan nama dan nilai dengan membuat keputusan semula). Setiap () mengembalikan benar hanya apabila semua keadaan kanak -kanak dalam kumpulan keadaan berpuas hati. Ini memastikan bahawa produk yang kami tapis mesti memenuhi semua atribut dalam kumpulan keadaan pada masa yang sama.
  • product.options.some (option => option.name === name && option.value === Value) : Ini adalah logik yang sepadan dalam. Untuk setiap keadaan kanak -kanak bahawa kaedah setiap () adalah memeriksa (mis. {Name: 'saiz', nilai: '10'}), kami melangkah melalui pelbagai pilihan produk semasa. Kaedah beberapa () memeriksa sama ada terdapat sekurang -kurangnya satu pilihan dalam Product.Options, yang namanya dan nilai tepat sesuai dengan keadaan kanak -kanak. Sekiranya dijumpai, benar dikembalikan, menunjukkan bahawa sub-keadaan berpuas hati.

Struktur bersarang ini dengan tepat melaksanakan logik bahawa "produk memenuhi mana -mana kumpulan keadaan dalam pelbagai keadaan, dan semua subkondisi dalam setiap kumpulan keadaan dipadankan dengan sebarang pilihan produk itu sendiri."

Nota dan amalan terbaik

  1. Kejelasan Logik : Walaupun fungsi berbilang lapisan ini bersarang lebih tinggi pesanan berkuasa, ia boleh membuat kod sukar untuk difahami dan diselenggarakan jika disalahgunakan atau logiknya tidak jelas. Pastikan tanggungjawab setiap penapis, beberapa, dan setiap jelas.
  2. Pertimbangan Prestasi : Untuk set data yang sangat besar, gelung bersarang berbilang lapisan mungkin mempunyai overhead prestasi. Sekiranya prestasi menjadi kesesakan, strategi pengoptimuman lain boleh dipertimbangkan, seperti data pra -proses, menggunakan peta untuk mencari cepat, atau dalam beberapa kes menggunakan tradisional untuk gelung untuk kawalan yang lebih baik. Walau bagaimanapun, untuk kebanyakan senario aplikasi web, pendekatan ini boleh diterima dan mempunyai kebolehbacaan kod yang lebih baik.
  3. Pemprosesan Arus Kosong : Pertimbangkan tingkah laku apabila produk atau keadaan adalah tatasusunan kosong. Apabila memproses tatasusunan kosong, penapis, beberapa, setiap, dan lain -lain. Kaedah biasanya mengembalikan hasil yang diharapkan (contohnya, beberapa pulangan palsu pada tatasusunan kosong, dan semuanya kembali benar), tetapi mereka masih perlu diuji mengikut logik perniagaan tertentu.
  4. Kesaksamaan yang ketat : Apabila membandingkan nama dan nilai, gunakan === (ketat kesamaan) dan bukannya == untuk mengelakkan masalah penukaran jenis yang berpotensi.

Meringkaskan

Dengan menggabungkan penapis (), beberapa () dan setiap () kaedah JavaScript, kita dapat menyelesaikan masalah penapisan objek bersarang berdasarkan keadaan kompleks. Corak ini bukan sahaja menyediakan keupayaan pemeriksaan data yang kuat, tetapi juga meningkatkan kebolehbacaan dan deklarasi kod. Memahami tingkah laku fungsi pesanan yang lebih tinggi dan kebolehgunaannya dalam senario yang berbeza adalah langkah utama untuk menjadi pemaju JavaScript yang sangat baik. Apabila berhadapan dengan cabaran pemprosesan data yang sama, mengutamakan penyelesaian ini untuk pengaturcaraan berfungsi.

Atas ialah kandungan terperinci Panduan untuk menapis susunan objek bersarang secara efisien berdasarkan keadaan kompleks dalam javascript. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

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.

Stock Market GPT

Stock Market GPT

Penyelidikan pelaburan dikuasakan AI untuk keputusan yang lebih bijak

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

JavaScript menyedari kesan penukaran imej klik: tutorial profesional JavaScript menyedari kesan penukaran imej klik: tutorial profesional Sep 18, 2025 pm 01:03 PM

Artikel ini akan memperkenalkan cara menggunakan JavaScript untuk mencapai kesan mengklik pada imej. Idea teras adalah menggunakan atribut data HTML5 untuk menyimpan laluan imej alternatif, dan mendengar klik acara melalui JavaScript, secara dinamik menukar atribut SRC, dengan itu menyedari penukaran imej. Artikel ini akan memberikan contoh dan penjelasan kod terperinci untuk membantu anda memahami dan menguasai kesan interaktif yang biasa digunakan ini.

Bagaimana untuk mendapatkan lokasi pengguna dengan API Geolokasi di JavaScript? Bagaimana untuk mendapatkan lokasi pengguna dengan API Geolokasi di JavaScript? Sep 21, 2025 am 06:19 AM

Pertama, periksa sama ada penyemak imbas menyokong GeolocationAPI. Jika disokong, hubungi getCurrentPosition () untuk mendapatkan koordinat lokasi semasa pengguna, dan dapatkan nilai latitud dan longitud melalui panggilan balik yang berjaya. Pada masa yang sama, berikan pengecualian pengendalian panggilan balik ralat seperti kebenaran penafian, ketiadaan lokasi atau tamat masa. Anda juga boleh lulus dalam pilihan konfigurasi untuk membolehkan ketepatan yang tinggi, menetapkan tempoh masa dan tempoh kesahihan cache. Seluruh proses memerlukan kebenaran pengguna dan pengendalian ralat yang sepadan.

Cara membuat selang berulang dengan setInterval dalam javascript Cara membuat selang berulang dengan setInterval dalam javascript Sep 21, 2025 am 05:31 AM

Untuk membuat selang pengulangan dalam JavaScript, anda perlu menggunakan fungsi setInterval (), yang akan berulang kali melaksanakan fungsi atau blok kod pada selang milisaat tertentu. Sebagai contoh, setInterval (() => {console.log ("melaksanakan setiap 2 saat");}, 2000) akan mengeluarkan mesej setiap 2 saat sehingga dibersihkan oleh ClearInterval (intervalid). Ia boleh digunakan dalam aplikasi sebenar untuk mengemas kini jam, pelayan pengundian, dan lain -lain, tetapi memberi perhatian kepada had kelewatan minimum dan kesan masa pelaksanaan fungsi, dan membersihkan selang waktu ketika tidak lagi diperlukan untuk mengelakkan kebocoran ingatan. Terutama sebelum pemotongan komponen atau penutupan halaman, pastikan bahawa

API Komposisi NUXT 3 dijelaskan API Komposisi NUXT 3 dijelaskan Sep 20, 2025 am 03:00 AM

Penggunaan teras API komposisi NUXT3 termasuk: 1. DefinePagemeta digunakan untuk menentukan maklumat meta halaman, seperti tajuk, susun atur dan middleware, yang perlu dipanggil terus di dalamnya dan tidak boleh diletakkan dalam pernyataan bersyarat; 2. Usehead digunakan untuk menguruskan tag header halaman, menyokong kemas kini statik dan responsif, dan perlu bekerjasama dengan DefinePagemeta untuk mencapai pengoptimuman SEO; 3. UseasyncData digunakan untuk mendapatkan data asynchronous secara selamat, secara automatik mengendalikan status pemuatan dan ralat, dan menyokong kawalan pemerolehan data pelayan dan klien; 4. UseFetch adalah enkapsulasi useasyncdata dan $ ambil, yang secara automatik memasuki kunci permintaan untuk mengelakkan permintaan pendua

Perangkap biasa dan penyelesaian untuk akses elemen DOM di JavaScript Perangkap biasa dan penyelesaian untuk akses elemen DOM di JavaScript Sep 15, 2025 pm 01:24 PM

Artikel ini bertujuan untuk menyelesaikan masalah kembali null apabila mendapatkan unsur -unsur DOM melalui document.getElementById () dalam JavaScript. Inti adalah untuk memahami masa pelaksanaan skrip dan status parsing DOM. Dengan betul meletakkan tag atau menggunakan acara domcontentloaded, anda dapat memastikan bahawa elemen itu dicuba lagi apabila ia tersedia, dengan berkesan mengelakkan kesilapan tersebut.

Pemformatan nombor dalam JavaScript: Gunakan kaedah Tofixed () untuk mengekalkan tempat perpuluhan tetap Pemformatan nombor dalam JavaScript: Gunakan kaedah Tofixed () untuk mengekalkan tempat perpuluhan tetap Sep 16, 2025 am 11:57 AM

Tutorial ini menerangkan secara terperinci bagaimana untuk memformat nombor ke dalam rentetan dengan dua perpuluhan tetap dalam JavaScript, walaupun bilangan bulat boleh dipaparkan dalam bentuk "#.00". Kami akan memberi tumpuan kepada penggunaan number.Prototype.TOfixed (), termasuk sintaksnya, fungsi, kod sampel, dan mata utama yang perlu diperhatikan, seperti jenis pulangannya sentiasa menjadi rentetan.

Bagaimana cara menyalin teks ke papan klip di JavaScript? Bagaimana cara menyalin teks ke papan klip di JavaScript? Sep 18, 2025 am 03:50 AM

Gunakan kaedah WriteText Clipboardapi untuk menyalin teks ke papan klip, ia perlu dipanggil dalam konteks keselamatan dan interaksi pengguna, menyokong penyemak imbas moden, dan versi lama boleh diturunkan dengan execcommand.

Bagaimana untuk membuat rentetan berbilang baris dalam JavaScript? Bagaimana untuk membuat rentetan berbilang baris dalam JavaScript? Sep 20, 2025 am 06:11 AM

TheBestatorreateamulti-LinestringinjavascriptsisingSisisingTemplatalAlalSwithBackTticks, yangPreserveticks, whoPreserverekeandeexactlyaswritten.

See all articles