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
Lepaskan: 2024-11-30 02:19:12
asal
484 orang telah melayarinya

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 } };
Salin selepas log masuk

Untuk mengakses nilai b2, anda biasanya boleh menggunakan :

r.b.b2
r['b']['b2']
Salin selepas log masuk

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
Salin selepas log masuk

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
Salin selepas log masuk

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!

sumber:php.cn
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