Rumah >hujung hadapan web >tutorial js >Menambahkan Sifat Dinamakan pada Tatasusunan JavaScript: Notasi Literal Objek lwn. Kurungan?

Menambahkan Sifat Dinamakan pada Tatasusunan JavaScript: Notasi Literal Objek lwn. Kurungan?

Patricia Arquette
Patricia Arquetteasal
2024-11-29 04:36:17765semak imbas

Adding Named Properties to JavaScript Arrays: Object Literal vs. Bracket Notation?

Menambahkan Sifat Dinamakan pada Tatasusunan: Keunikan JavaScript

Dalam JavaScript, tatasusunan boleh dimanipulasi dengan cara yang tidak dijangka, termasuk keupayaan untuk menambah bernama sifat seolah-olah ia adalah objek. Ini menimbulkan persoalan: Adakah terdapat perbezaan asas antara mengisytiharkan tatasusunan dengan sifat bernama menggunakan kurungan berbanding objek literal?

Jawapan ringkasnya ialah: Ya, terdapat perbezaan.

Walaupun kedua-dua kaedah berkelakuan serupa dan mengembalikan jenis 'objek' apabila disemak dengan typeof(), ia berbeza dalam sifat asasnya. Tatasusunan bertujuan untuk data yang diindeks secara berangka, manakala objek direka untuk kekunci bukan angka.

Untuk menggambarkan perbezaan ini, pertimbangkan perkara berikut:

var myArray = Array();
myArray['A'] = "Athens";
myArray['B'] = "Berlin";

alert(myArray.length);

Kod ini akan memaparkan '0', sedangkan seseorang mungkin mengharapkan ia memaparkan '2'. Ini kerana sifat yang dinamakan ditambahkan pada tatasusunan tidak menjejaskan sifat panjangnya. Sebaliknya, ia dianggap sebagai sifat tambahan pada objek tatasusunan.

Sebaliknya, objek literal yang diisytiharkan dengan sifat dinamakan akan mencerminkan panjangnya dengan betul:

var myObject = {'A': 'Athens', 'B': 'Berlin'};
alert(myObject.length); // This would display '2'

Oleh itu, sementara ia mungkin untuk menambah sifat bernama pada tatasusunan, ia dianggap sebagai "penyalahgunaan" dan harus dielakkan. Untuk kekunci bukan angka, amalan terbaik adalah menggunakan objek sebaliknya.

Atas ialah kandungan terperinci Menambahkan Sifat Dinamakan pada Tatasusunan JavaScript: Notasi Literal Objek lwn. Kurungan?. 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