Rumah > hujung hadapan web > tutorial js > Mengapa Pembolehubah `nama` JavaScript Berkelakuan Berbeza Merentasi Pelayar Apabila Digunakan dengan Objek?

Mengapa Pembolehubah `nama` JavaScript Berkelakuan Berbeza Merentasi Pelayar Apabila Digunakan dengan Objek?

Susan Sarandon
Lepaskan: 2025-01-01 10:47:09
asal
554 orang telah melayarinya

Why Does JavaScript's `name` Variable Behave Differently Across Browsers When Used with Objects?

Windows Variable 'name' Berkelakuan Berbeza dengan Objek

Dalam JavaScript, mentakrifkan pembolehubah dengan nama simpanan 'nama' boleh membawa kepada tingkah laku yang tidak dijangka apabila bekerja dengan objek.

Dalam coretan berikut, Chrome berkelakuan berbeza daripada yang lain pelayar:

var name = {};
name.FirstName = 'Tom';
alert(name.FirstName); // undefined in Chrome, 'Tom' in IE/Firefox
Salin selepas log masuk

Anomali ini timbul kerana 'nama' mempunyai tujuan khas dalam objek tetingkap penyemak imbas. Walaupun IE dan Firefox menganggap 'nama' sebagai objek biasa yang boleh memegang sifat, Chrome mentafsirkannya sebagai rentetan primitif dan menghantarnya dengan sewajarnya.

Oleh itu, memberikan objek kepada 'nama' pembolehubah (var name = {}) secara tersirat menetapkan sifat window.name kepada nilai rentetan "[objek Objek]". Penukaran ini memecahkan gelagat objek yang dijangkakan, menjadikannya mustahil untuk menetapkan atau mengakses sifat pada 'nama', seperti yang dilihat dalam perkara berikut:

alert(name); // "[object Object]"
Salin selepas log masuk

Untuk mengelakkan isu ini, adalah disyorkan untuk mengelak daripada menggunakan 'nama' sebagai nama pembolehubah global, terutamanya apabila bekerja dengan objek. Sebagai alternatif, anda boleh menggunakan nama pembolehubah lain atau pertimbangkan untuk menggunakan ruang nama untuk mengelakkan perlanggaran nama.

Atas ialah kandungan terperinci Mengapa Pembolehubah `nama` JavaScript Berkelakuan Berbeza Merentasi Pelayar Apabila Digunakan dengan 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