Rumah >hujung hadapan web >tutorial js >Bagaimana untuk mengalih keluar Item Tertentu Dari Array dalam JavaScript?
Adalah perkara biasa untuk perlu mengalih keluar nilai tertentu daripada tatasusunan dalam JavaScript. Dalam siaran ini, saya akan menunjukkan kepada anda bukan sahaja cara untuk berbuat demikian, tetapi juga cara untuk melaksanakannya seolah-olah ia adalah kaedah asli pada tatasusunan, dengan fleksibiliti untuk mengendalikan pelbagai jenis data, termasuk objek, primitif dan logik perbandingan tersuai .
Sebelum kita bermula, saya ingin menjemput anda melawat 0dev, platform data sumber terbuka yang berfungsi dengan bahasa semula jadi. Gunakan 0dev untuk mengakses data anda tanpa pertanyaan SQL yang kompleks, visualisasikannya tanpa sebarang pengekodan dan jana cerapan tanpa sebarang pengalaman sains data.
Repositori: https://github.com/0dev-hq/0dev
Mari buat kaedah alih keluar tersuai pada tatasusunan JavaScript, membenarkannya mengalih keluar kejadian pertama nilai secara lalai atau semua kejadian apabila dinyatakan. Selain itu, kami akan meningkatkannya dengan menambahkan sokongan untuk fungsi pembanding, memberikan kami kawalan ke atas cara nilai dipadankan.
Array.prototype.remove = function(value, removeAll = false, comparator = (a, b) => a === b) { if (removeAll) { return this.filter(item => !comparator(item, value)); } else { const index = this.findIndex(item => comparator(item, value)); if (index !== -1) this.splice(index, 1); // Remove the item if found return this; } };
Menambah keluarkan pada Array.prototype menjadikan fungsi ini tersedia terus pada mana-mana contoh tatasusunan, sama seperti kaedah asli seperti peta, penapis atau splice.
Parameter removeAll menyediakan cara mudah untuk mengawal tingkah laku kaedah. Secara lalai, removeAll ditetapkan kepada palsu, bermakna hanya kejadian pertama nilai yang ditentukan akan dialih keluar. Jika removeAll ditetapkan kepada benar, kaedah akan mengalih keluar semua kejadian nilai yang ditentukan.
Parameter pembanding mungkin kelihatan berlebihan pada mulanya, tetapi ia menambahkan lebih fleksibiliti kepada kaedah ini. Apabila bekerja dengan tatasusunan objek, anda perlu memadankan nilai berdasarkan sifat dan bukannya kesamaan mudah, di sinilah parameter pembanding berguna.
Sebagai contoh, jika anda mempunyai tatasusunan objek pengguna dan ingin mengalih keluar pengguna dengan nama tertentu, anda boleh menggunakan fungsi pembanding untuk membandingkan berdasarkan sifat nama.
Untuk kes penggunaan asas dengan nilai primitif seperti nombor, kaedah alih keluar berfungsi dengan lancar.
javascriptCopy codelet numbers = [1, 2, 3, 4, 2]; numbers = numbers.remove(2); // Removes the first occurrence of 2 console.log(numbers); // Output: [1, 3, 4, 2] numbers = numbers.remove(2, true); // Removes all occurrences of 2 console.log(numbers); // Output: [1, 3, 4]
Di sini, alih keluarSemua lalai kepada palsu, hanya mengalih keluar kejadian pertama. Menetapkan removeAll kepada true mengalih keluar semua 2s daripada tatasusunan.
Apabila berurusan dengan tatasusunan objek, fungsi pembanding boleh menentukan dengan tepat cara kaedah itu harus mengenal pasti padanan.
javascriptCopy codelet people = [ { id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }, { id: 3, name: 'Alice' } ]; // Remove all occurrences of objects with the name 'Alice' people = people.remove({ name: 'Alice' }, true, (a, b) => a.name === b.name); console.log(people); // Output: [{ id: 2, name: 'Bob' }]
Selamat pengekodan! :)
Atas ialah kandungan terperinci Bagaimana untuk mengalih keluar Item Tertentu Dari Array dalam JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!