Jadual Kandungan
Gunakan map untuk "menukar array"
Gunakan filter untuk memilih data yang memenuhi kriteria
Gunakan reduce kepada "Arahan Synthese menjadi satu hasil"
Contoh kecil penggunaan gabungan sebenar
Rumah hujung hadapan web tutorial js Bagaimana cara menggunakan peta, penapis, dan mengurangkan JS?

Bagaimana cara menggunakan peta, penapis, dan mengurangkan JS?

Jun 27, 2025 am 12:48 AM

Peta, penapis dan mengurangkan kaedah dalam JavaScript digunakan untuk mengubah data, menapis data, dan menggabungkan data masing -masing. 1. Peta menghasilkan array baru dengan memproses setiap item array, yang sesuai untuk format penukaran atau medan pengekstrakan; 2. Penapis mengekalkan data yang memenuhi syarat melalui penapisan bersyarat, yang sesuai untuk menapis kandungan tidak sah atau mencari dengan bersyarat; 3. Mengurangkan menggabungkan array ke dalam nilai, yang sering digunakan untuk penjumlahan, statistik atau kumpulan. Gabungan ketiga -tiga ini dapat memproses operasi data yang kompleks dan meningkatkan kejelasan kod dan kesederhanaan.

Bagaimana cara menggunakan peta, penapis, dan mengurangkan JS?

map , filter dan reduce adalah tiga kaedah array yang sangat biasa di JavaScript yang membolehkan anda memproses data lebih ringkas. Daripada menggunakan sekumpulan for gelung dan pembolehubah pertengahan, lebih baik menggunakan kaedah ini untuk menjadikan kod lebih jelas.

Bagaimana cara menggunakan peta, penapis, dan mengurangkan JS?

Mari kita bercakap tentang cara menggunakannya dan di mana senario mereka paling sesuai.

Bagaimana cara menggunakan peta, penapis, dan mengurangkan JS?

Gunakan map untuk "menukar array"

Fungsi map adalah untuk "memproses" setiap item dalam array dan mengembalikan array baru. Ia tidak mengubah suai array asal, tetapi menghasilkan nilai baru berdasarkan fungsi yang anda berikan.

Contohnya: Anda ingin membiak pelbagai nombor dengan 2:

Bagaimana cara menggunakan peta, penapis, dan mengurangkan JS?
 nombor const = [1, 2, 3, 4];
const doubled = number.map (n => n * 2);
// Keputusan: [2, 4, 6, 8]

Senario yang terpakai:

  • Tukar rentetan ke huruf besar atau huruf kecil
  • Ekstrak medan dari pelbagai objek untuk membentuk array baru
  • Format setiap item (seperti masa dan jumlah)

Catatan:

  • Jika anda kembali undefined dalam map , kedudukan yang sama dari array baru adalah nilai null.
  • Jangan lakukan kesan sampingan dalam fungsi ini, seperti menghantar permintaan atau mengubahsuai DOM.

Gunakan filter untuk memilih data yang memenuhi kriteria

Seperti namanya, filter digunakan untuk "penapis". Ia akan melangkah ke atas setiap item dalam array, dan jika fungsi panggil balik kembali true , ia akan menyimpan item ini, jika tidak, ia tidak akan dipelihara.

Sebagai contoh, cari semua nombor yang lebih besar daripada 10:

 const nums = [5, 12, 8, 17];
const bignums = nums.filter (n => n> 10);
// Keputusan: [12, 17]

Kegunaan biasa:

  • Tapis data tidak sah (seperti null atau tidak ditentukan)
  • Kandungan cari berdasarkan kata kunci
  • Tugas penapis dengan status "siap" dll.

Kemahiran:

  • Anda boleh menggabungkan includes untuk membuat padanan kabur
  • Apabila menapis melalui pelbagai syarat, anda boleh menggunakan pelbagai filter atau menambah pertimbangan logik.

Gunakan reduce kepada "Arahan Synthese menjadi satu hasil"

reduce adalah yang paling kuat dan sukar difahami. Ia boleh "menggabungkan" array ke dalam nilai, seperti jumlah, nilai maksimum, pengelompokan objek, dll.

Struktur asas ialah:

 array.reduce ((penumpuk, currentValue) => {...}, nilai awal)

Sebagai contoh, jumlah:

 scor const = [10, 20, 30];
const total = scores.reduce ((jumlah, skor) => skor jumlah, 0);
// Keputusan: 60

Apa lagi yang boleh saya buat?

  • Statistik bilangan kejadian (seperti mengira berapa kali seseorang muncul)
  • Tukar tatasusunan menjadi peta objek
  • Data kumpulan (seperti dikelaskan mengikut jenis)

NOTIS:

  • Jangan lupa nilai awal, jika tidak, ia akan membawa kepada kesilapan dengan mudah
  • Parameter pertama fungsi panggil balik adalah hasil daripada "terkumpul" anda, dan yang kedua adalah item semasa

Contoh kecil penggunaan gabungan sebenar

Katakan anda mempunyai senarai pesanan dan anda ingin mencari pesanan dengan harga keseluruhan lebih daripada 100 dan mengira jumlahnya:

 Perintah const = [
  {id: 1, jumlah: 50},
  {id: 2, jumlah: 120},
  {id: 3, jumlah: 80},
  {id: 4, jumlah: 200}
];

jumlah const = pesanan
  .Filter (order => order.Amount> 100)
  .map (order => order.amount)
  .reduce ((jumlah, jumlah) => jumlah jumlah, 0);

// hasil: 320

Panggilan rantaian semacam ini sangat biasa dan intuitif.


Pada dasarnya itu sahaja. Ketiga kaedah ini masing -masing melaksanakan tugas mereka:

  • Data transformasi map
  • data penapis filter
  • reduce data gabungan

Menguasai mereka dan anda akan mendapati bahawa tatasusunan pemprosesan menjadi cepat dan bersih.

Atas ialah kandungan terperinci Bagaimana cara menggunakan peta, penapis, dan mengurangkan JS?. 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.

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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

Tutorial PHP
1522
276
Skop dan konteks JavaScript maju Skop dan konteks JavaScript maju Jul 24, 2025 am 12:42 AM

Skop JavaScript menentukan skop kebolehcapaian pembolehubah, yang dibahagikan kepada skop global, fungsi dan tahap blok; Konteks menentukan arah ini dan bergantung kepada kaedah panggilan fungsi. 1. Skop termasuk skop global (boleh diakses di mana sahaja), skop fungsi (hanya sah dalam fungsi), dan skop peringkat blok (biarkan dan const sah dalam {}). 2. Konteks pelaksanaan mengandungi objek pembolehubah, rantaian skop dan nilai -nilai ini. Ini menunjukkan kepada global atau tidak ditentukan dalam fungsi biasa, kaedah panggilan kaedah ke objek panggilan, pembina menunjuk ke objek baru, dan juga boleh ditentukan secara jelas oleh panggilan/memohon/mengikat. 3. Penutupan merujuk kepada fungsi mengakses dan mengingati pembolehubah skop luaran. Mereka sering digunakan untuk enkapsulasi dan cache, tetapi boleh menyebabkan

Vue 3 Composition API vs Pilihan API: Perbandingan Terperinci Vue 3 Composition API vs Pilihan API: Perbandingan Terperinci Jul 25, 2025 am 03:46 AM

COMPOSISAPI dalam VUE3 lebih sesuai untuk logik dan jenis derivasi yang kompleks, dan OptionsAPI sesuai untuk senario dan pemula yang mudah; 1. Optionsapi menganjurkan kod mengikut pilihan seperti data dan kaedah, dan mempunyai struktur yang jelas tetapi komponen kompleks dipecah -pecah; 2. CompositionAPI menggunakan persediaan untuk menumpukan logik yang berkaitan, yang kondusif untuk penyelenggaraan dan penggunaan semula; 3. Compositionapi menyedari penggunaan semula logik bebas konflik dan parameternya melalui fungsi kompos yang lebih baik daripada Mixin; 4. CompositionAPI mempunyai sokongan yang lebih baik untuk typescript dan derivasi jenis yang lebih tepat; 5. Tidak terdapat perbezaan yang signifikan dalam jumlah prestasi dan pembungkusan kedua -duanya; 6.

Meneroka Peraturan Paksaan Jenis dalam JavaScript Meneroka Peraturan Paksaan Jenis dalam JavaScript Jul 21, 2025 am 02:31 AM

Pemutus jenis adalah tingkah laku secara automatik menukar satu jenis nilai kepada jenis lain dalam JavaScript. Senario biasa termasuk: 1. Apabila menggunakan pengendali, jika satu sisi adalah rentetan, sisi lain juga akan ditukar kepada rentetan, seperti '5' 5. Hasilnya ialah "55"; 2. 3. Null mengambil bahagian dalam operasi berangka dan akan ditukar kepada 0, dan undefined akan ditukar kepada NAN; 4. Masalah yang disebabkan oleh penukaran tersirat boleh dielakkan melalui fungsi penukaran eksplisit seperti nombor (), rentetan (), dan boolean (). Menguasai peraturan ini membantu

Menguasai Corak Konvensyen JavaScript: Pekerja Web vs Java Threads Menguasai Corak Konvensyen JavaScript: Pekerja Web vs Java Threads Jul 25, 2025 am 04:31 AM

Terdapat perbezaan penting antara pekerja web JavaScript dan Javathreads dalam pemprosesan serentak. 1. JavaScript mengamalkan model tunggal-thread. WebWorkers adalah benang bebas yang disediakan oleh penyemak imbas. Ia sesuai untuk melaksanakan tugas-tugas yang memakan masa yang tidak menghalang UI, tetapi tidak dapat mengendalikan DOM; 2. Java menyokong multithreading sebenar dari tahap bahasa, yang dibuat melalui kelas thread, sesuai untuk logik serentak dan pemprosesan sisi serentak; 3. WebWorkers menggunakan postmessage () untuk berkomunikasi dengan benang utama, yang sangat selamat dan terpencil; Benang Java boleh berkongsi ingatan, jadi isu penyegerakan perlu diberi perhatian; 4. Pekerja web lebih sesuai untuk pengkomputeran selari depan, seperti pemprosesan imej, dan

Bagaimana cara memformat tarikh di JS? Bagaimana cara memformat tarikh di JS? Jul 20, 2025 am 12:10 AM

Tarikh format dalam JavaScript boleh dilaksanakan melalui kaedah asli atau perpustakaan pihak ketiga. 1. Gunakan Jahitan Objek Tarikh Asli: Dapatkan bahagian tarikh melalui getfuleear, getmonth, getdate dan kaedah lain, dan secara manual menyambungkannya ke yyyy-mm-dd dan format lain, yang sesuai untuk keperluan ringan dan tidak bergantung pada perpustakaan pihak ketiga; 2. Gunakan kaedah tolocaledatestring: anda boleh output seperti format mm/dd/yyyy mengikut tabiat tempatan, menyokong pelbagai bahasa, tetapi formatnya mungkin tidak konsisten kerana persekitaran yang berbeza; 3. Gunakan perpustakaan pihak ketiga seperti hari.js atau tarikh-FNS: Menyediakan sintaks ringkas dan fungsi yang kaya, sesuai untuk operasi yang kerap atau apabila kelanjutan diperlukan, seperti dayjs ()

Membina alat CLI dengan node.js Membina alat CLI dengan node.js Jul 24, 2025 am 03:39 AM

Memulakan projek dan buat pakej.json; 2. Buat skrip kemasukan index.js dengan shebang; 3. Daftar perintah melalui medan bin dalam pakej.json; 4. Gunakan Yargs dan perpustakaan lain untuk menghuraikan parameter baris arahan; 5. Gunakan ujian tempatan NPMLink; 6. Tambah bantuan, versi dan pilihan untuk meningkatkan pengalaman; 7. Secara pilihan menerbitkan melalui NPMPublish; 8. Secara pilihan mencapai penyelesaian automatik dengan YARGS; Akhirnya buat alat CLI praktikal melalui struktur yang munasabah dan reka bentuk pengalaman pengguna, tugas automasi lengkap atau mengedarkan widget, dan berakhir dengan ayat lengkap.

Bagaimana untuk membuat dan menambahkan elemen di JS? Bagaimana untuk membuat dan menambahkan elemen di JS? Jul 25, 2025 am 03:56 AM

Gunakan document.createelement () untuk membuat elemen baru; 2. Sesuaikan elemen melalui textContent, classlist, setAttribute dan kaedah lain; 3. Gunakan kaedah tambahan () atau lebih fleksibel () untuk menambah elemen ke DOM; 4. Secara pilihan menggunakan InsertBefore (), sebelum () dan kaedah lain untuk mengawal kedudukan penyisipan; Proses lengkap adalah untuk membuat → Sesuaikan → Tambah, dan anda boleh mengemas kini kandungan halaman secara dinamik.

Jenis Bersyarat Lanjutan dalam TypeScript Jenis Bersyarat Lanjutan dalam TypeScript Aug 04, 2025 am 06:32 AM

Jenis Keadaan Lanjutan TypeScript Melaksanakan penghakiman logik antara jenis melalui Textendsu? X: Y Sintaks. Keupayaan terasnya ditunjukkan dalam jenis keadaan yang diedarkan, kesimpulan jenis kesimpulan dan pembinaan alat jenis kompleks. 1. Jenis bersyarat diedarkan dalam parameter jenis kosong dan secara automatik boleh memecah jenis bersama, seperti toarray untuk mendapatkan rentetan [] | number []. 2. Menggunakan Pengagihan untuk Membina Alat Penapisan dan Pengekstrakan: Tidak termasuk Kecualikan Jenis Melalui Textendsu? Tidak pernah: T, Ekstrak Ekstrak Persamaan melalui Textendsu? 3

See all articles