Rumah > hujung hadapan web > tutorial js > Bagaimanakah saya boleh menukar rentetan JavaScript dalam notasi titik menjadi rujukan objek?

Bagaimanakah saya boleh menukar rentetan JavaScript dalam notasi titik menjadi rujukan objek?

Linda Hamilton
Lepaskan: 2024-12-19 18:19:09
asal
729 orang telah melayarinya

How can I convert a JavaScript string in dot notation into an object reference?

Tukar String JavaScript dalam Notasi Titik kepada Rujukan Objek

Dalam JavaScript, menavigasi sifat objek menggunakan tatatanda titik ialah amalan biasa dan mudah . Walau bagaimanapun, mungkin terdapat situasi di mana anda mempunyai rentetan yang mewakili hierarki yang dipisahkan titik dan perlu menukarnya menjadi rujukan objek untuk akses mudah.

Pernyataan Masalah:

Memandangkan objek dan rentetan dalam notasi titik, bagaimana anda boleh menukar rentetan itu menjadi rujukan objek untuk mengakses yang sepadan harta?

Contoh:

Pertimbangkan objek berikut:

var obj = { a: { b: '1', c: '2' } }
Salin selepas log masuk

Dan rentetan:

"a.b"
Salin selepas log masuk

Bagaimana bolehkah anda menukar "a.b" untuk mendapatkan semula nilai yang dikaitkan dengan obj.a.b?

Penyelesaian:

Terdapat beberapa kaedah untuk mencapai perkara ini:

1. Menggunakan Fungsi eval() (TIDAK DISYORKAN):

eval("var val = obj." + string);
Salin selepas log masuk

Penyelesaian ini secara langsung menilai rentetan sebagai kod dan memberikan hasilnya kepada val. Walau bagaimanapun, penggunaan eval() secara amnya tidak digalakkan kerana kebimbangan keselamatan.

2. Menggunakan Operator [] (Kaedah Tidak Langsung):

var val = obj[string];
Salin selepas log masuk

Kaedah ini menggunakan sintaks kurungan segi empat sama untuk mengakses sifat secara tidak langsung. Ia berfungsi apabila rentetan ialah pengecam JavaScript yang sah (cth., tiada ruang atau aksara khas).

3. Menggunakan Kaedah reduce():

var val = string.split('.').reduce(function(obj, i) { return obj[i]; }, obj);
Salin selepas log masuk

Penyelesaian ini membelah rentetan dengan aksara noktah (.) dan menggunakan kaedah reduce() untuk melintasi hierarki objek, bermula dari objek akar.

4. Menggunakan Fungsi multiIndex():

var val = multiIndex(obj, string.split('.'));

function multiIndex(obj, is) {
    return is.length ? multiIndex(obj[is[0]],is.slice(1)) : obj
}
Salin selepas log masuk

Penyelesaian ini secara rekursif merentasi hierarki objek sehingga sifat yang dikehendaki ditemui. Ia mengendalikan kedua-dua tatatanda titik berbilang peringkat dan tatasusunan (jika perlu).

Mengendalikan Tatasusunan (Pilihan):

Sekiranya rentetan mengandungi indeks tatasusunan, anda boleh menggunakan pendekatan berikut:

var val = string.match(/[^\]\[.]+/g).reduce(function(obj, i) { return obj[i]; }, obj);
Salin selepas log masuk

Tambahan Nota:

  • Pertimbangkan implikasi prestasi apabila menggunakan rekursi atau reduce(), terutamanya untuk hierarki objek yang besar atau kompleks.
  • Pastikan rentetan input dibersihkan untuk mengelakkan kod hasad pelaksanaan.
  • Kunci sifat dalam JavaScript sentiasa rentetan, jadi rujukan objek menggunakan notasi titik sememangnya berasaskan rentetan.

Atas ialah kandungan terperinci Bagaimanakah saya boleh menukar rentetan JavaScript dalam notasi titik menjadi rujukan objek?. 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