Rumah  >  Artikel  >  hujung hadapan web  >  Bagaimana untuk Melintasi Objek (Pokok) Secara Rekursif dalam JavaScript atau jQuery?

Bagaimana untuk Melintasi Objek (Pokok) Secara Rekursif dalam JavaScript atau jQuery?

Linda Hamilton
Linda Hamiltonasal
2024-10-22 20:56:10316semak imbas

How to Traverse an Object (Tree) Recursively in JavaScript or jQuery?

Gelung melalui Objek (Pokok) Secara Rekursif

Dalam JavaScript atau jQuery, melintasi objek dan keturunannya boleh dicapai menggunakan for. ..dalam gelung:

<code class="javascript">for (var key in foo) {
  if (key == "child") {
    // Do something with child
  }
  if (key == "bar") {
    // Do something with bar
  }
  if (key == "grand") {
    // Do something with grand
  }
}</code>

Perhatikan bahawa untuk...dalam gelung berulang ke atas semua sifat terhitung, termasuk yang diwarisi daripada prototaip objek. Untuk mengelak daripada bertindak pada sifat yang diwarisi, gunakan hasOwnProperty:

<code class="javascript">for (var key in foo) {
  if (!foo.hasOwnProperty(key)) continue;
  if (key == "child") {
    // Do something with child
  }
}</code>

Gelung Rekursif

Untuk menggelung secara rekursif, cipta fungsi rekursif:

<code class="javascript">function eachRecursive(obj) {
  for (var key in obj) {
    if (typeof obj[key] === "object" &amp;&amp; obj[key] !== null) {
      eachRecursive(obj[key]);
    } else {
      // Do something with primitive value
    }
  }
}</code>

Fungsi ini boleh mengendalikan kedua-dua objek dan tatasusunan, merentasi struktur bersarangnya secara rekursif.

Atas ialah kandungan terperinci Bagaimana untuk Melintasi Objek (Pokok) Secara Rekursif dalam JavaScript atau jQuery?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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