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
Susan Sarandonasal
2025-01-01 10:47:09561semak imbas

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

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]"

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!

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