Rumah >hujung hadapan web >tutorial js >Bagaimana untuk Mengakses Sifat Objek Bersarang Menggunakan Rentetan Notasi Titik dalam JavaScript?

Bagaimana untuk Mengakses Sifat Objek Bersarang Menggunakan Rentetan Notasi Titik dalam JavaScript?

Susan Sarandon
Susan Sarandonasal
2024-11-30 02:19:12486semak imbas

How to Access Nested Object Properties Using Dot Notation Strings in JavaScript?

Mengakses Sifat Kanak-Kanak Objek melalui Rentetan Notasi Titik

Apabila berurusan dengan objek bersarang, mengakses sifat yang terkubur dalam boleh menyusahkan. Menentukan cara ideal untuk mencapai ini menggunakan tatatanda titik rentetan telah membingungkan banyak pembangun.

Pertimbangkan objek yang ditakrifkan seperti berikut:

var r = { a: 1, b: { b1: 11, b2: 99 } };

Untuk mengakses nilai b2, anda biasanya boleh menggunakan :

r.b.b2
r['b']['b2']

Walau bagaimanapun, mentakrifkan rentetan seperti var s = "b.b2" dan percubaan untuk mengakses r[s] atau r.s akan gagal.

Penyelesaian:

Satu kaedah melibatkan mencipta fungsi tersuai yang membelah rentetan pada titik dan secara berulang mendapatkan semula yang diingini harta benda. Contoh mudah ialah:

function getDescendantProp(obj, desc) {
    var arr = desc.split(".");
    while (arr.length && (obj = obj[arr.shift()]));
    return obj;
}

console.log(getDescendantProp(r, "b.b2")); // Outputs 99

Fungsi ini menurunkan hierarki objek secara rekursif berdasarkan laluan yang dipisahkan titik, mengembalikan nilai akhir. Terutama, ia juga boleh mengendalikan mengakses indeks tatasusunan menggunakan notasi titik:

console.log(getDescendantProp({ a: [1, 2, 3] }, 'a.2')); // Outputs 3

Atas ialah kandungan terperinci Bagaimana untuk Mengakses Sifat Objek Bersarang Menggunakan Rentetan Notasi Titik dalam JavaScript?. 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
Artikel sebelumnya:kata kunci &#new'Artikel seterusnya:kata kunci &#new'