Bagaimana untuk Mengelakkan Elemen Tambahan Apabila Menggelung Melalui Item Terpilih dengan document.querySelectorAll?

Patricia Arquette
Lepaskan: 2024-10-20 21:14:02
asal
183 orang telah melayarinya

How to Avoid Extra Elements When Looping Through Selected Items with document.querySelectorAll?

Menggelung Melalui Elemen Terpilih dengan document.querySelectorAll

Masalah:
Apabila cuba menggelung elemen yang dipilih menggunakan document.querySelectorAll, output termasuk item tambahan yang tidak berkaitan.

Contoh:

var checkboxes = document.querySelectorAll('.check');
for( i in checkboxes) {
  console.log(checkboxes[i]);
}
Salin selepas log masuk

Output:

<input id="check-1" class="check" type="checkbox" name="check">
<input id="check-2" class="check" type="checkbox" name="check">
<input id="check-3" class="check" type="checkbox" name="check">
<input id="check-4" class="check" type="checkbox" name="check">
<input id="check-5" class="check" type="checkbox" name="check">
<input id="check-6" class="check" type="checkbox" name="check">
<input id="check-7" class="check" type="checkbox" name="check">
<input id="check-8" class="check" type="checkbox" name="check">
<input id="check-9" class="check" type="checkbox" name="check">
<input id="check-10" class="check" type="checkbox" name="check" checked="">

10
item()
namedItem()
Salin selepas log masuk

Masalah timbul kerana document.querySelectorAll mengembalikan NodeList, iaitu objek seperti tatasusunan. Walau bagaimanapun, NodeList tidak menyokong kaedah tatasusunan seperti forEach.

Penyelesaian:

Untuk menggelungkan elemen yang dipilih dengan betul, tukar NodeList kepada tatasusunan. Terdapat beberapa cara untuk melakukan ini:

  1. Spread Syntax (ES2015 ):

    const divs = [...document.querySelectorAll('div')];
    divs.forEach((div) => {
      // Do something with each div
    });
    Salin selepas log masuk
  2. Array.from():

    const divs = Array.from(document.querySelectorAll('div'));
    divs.forEach((div) => {
      // Do something with each div
    });
    Salin selepas log masuk
  3. Menggelung pada indeks nod:

    const checkboxes = document.querySelectorAll('.check');
    for (let i = 0; i < checkboxes.length; i++) {
      // Do something with each checkbox
    }
    Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana untuk Mengelakkan Elemen Tambahan Apabila Menggelung Melalui Item Terpilih dengan document.querySelectorAll?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber: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
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!