Rumah > hujung hadapan web > tutorial js > Apa itu literal? Bagaimana untuk menggunakan literal untuk membuat objek dalam JS?

Apa itu literal? Bagaimana untuk menggunakan literal untuk membuat objek dalam JS?

青灯夜游
Lepaskan: 2022-08-04 18:03:52
ke hadapan
3167 orang telah melayarinya

Bagaimana untuk menggunakan literal untuk mencipta objek dalam JavaScript? Artikel berikut akan membawa anda memahami literal dan memperkenalkan cara menggunakan literal objek untuk mencipta objek dalam JavaScript. Saya harap ia akan membantu anda!

Apa itu literal? Bagaimana untuk menggunakan literal untuk membuat objek dalam JS?

Apa itu literal

Harta ialah tatatanda untuk menyatakan nilai tetap , juga dipanggil pemalar, digunakan untuk menetapkan nilai kepada pembolehubah

Dalam istilah orang awam, apa yang anda lihat ialah apa yang anda dapat Apabila program js melaksanakan literal dalam kod, ia akan segera mengetahui jenis data ia adalah , apakah nilainya?

boleh digunakan untuk mewakili nilai tetap, seperti: nombor, rentetan, tidak ditentukan, jenis Boolean, literal objek, dll.

Penciptaan literal objek Kaedah literal objek

ialah salah satu cara yang paling biasa digunakan untuk mencipta objek Ia menggunakan pendakap kerinting {...} yang mengandungi atribut untuk mencipta objek dengan cepat.

var 对象名={ 
    .....
};
Salin selepas log masuk

Objek literal ialah senarai sifar atau lebih "{}" objek yang disertakan dalam pasangan pendakap (属性名:值).

Contoh:

var person={ 
    name:"Jack", 
    age:10,
    5:true  
};
Salin selepas log masuk
  • Dalam contoh ini, pendakap kerinting kiri ({) mewakili <🎜 objek literal >Mula kerana ia muncul dalam konteks ungkapan.

  • Konteks ungkapan dalam JavaScript merujuk kepada keupayaan untuk mengembalikan nilai (ungkapan).

  • Operator tugasan (

    ) menunjukkan bahawa ia diikuti dengan nilai, jadi kurungan kerinting kiri di sini menunjukkan permulaan ungkapan. =

  • Kurung kurawal yang sama, jika ia muncul dalam konteks pernyataan, seperti mengikut syarat pernyataan if, menunjukkan permulaan blok pernyataan.

  • Dalam contoh, atribut nama ditakrifkan, diikuti dengan

    titik bertindih, dan kemudian nilai atribut ini (). Dalam literal objek, name:"Jack" menggunakan koma untuk memisahkan sifat yang berbeza , jadi "Jack" diikuti dengan koma. Tetapi , anda tidak boleh menambah koma selepas dengan nilai 10 atribut umur, kerana umur ialah atribut terakhir objek ini. Menambah koma selepas atribut terakhir akan menyebabkan ralat dalam IE7 dan sebelumnya serta Opera.

  • Jangan lupa (

    ) di sebelah kanan pendakap penutup ;

Jenisnya daripada nilai literal objek

Nilai literal objek boleh menjadi sebarang jenis data termasuk literal tatasusunan, fungsi, literal objek bersarang

var Swapper = {    
        // 数组字面量(用逗号分隔,所有都要加引号)
    images: ["smile.gif", "grim.gif", "frown.gif", "bomb.gif"],
    pos: { 
            //嵌套对象字面量
        x: 40,
        y: 300
    },
    onSwap: function() { 
            //函数
    }
};
Salin selepas log masuk
    Jika ada daripada peraturan sintaks ialah Pemecahan seperti tiada koma atau titik bertindih atau tanda kurung akan mencetuskan ralat JavaScript.
  • Mesej ralat penyemak imbas biasanya membantu dalam menunjukkan lokasi ralat sintaks literal objek, tetapi ia tidak semestinya tepat sepenuhnya dalam menunjukkan sifat ralat itu.

Apabila menggunakan literal objek, nama atribut juga boleh menjadi rentetan

var person={
    "name":"Jack",
    "age":29,
    5:true
};
Salin selepas log masuk
    Contoh di atas akan mencipta objek yang mengandungi tiga atribut , tetapi nama atribut angka di sini akan ditukar secara automatik kepada rentetan.
  • Apabila mentakrifkan objek melalui objek literal, pembina Objek sebenarnya tidak akan dipanggil (Firefox 2 dan lebih awal akan memanggil pembina Objek; tetapi ini tidak akan berlaku selepas Firefox 3)


    Ini kerana kaedah literal untuk mencipta objek menekankan bahawa objek itu hanya peta cincang boleh ubah, bukan sifat atau kaedah yang diekstrak daripada objek.

Apabila nama atribut dan nama pembolehubah adalah sama, ia boleh disingkatkan

var obj = { name: name, age: age };

// ES2015中,属性名和变量名相同时可简写为:
var obj = { name, age };
Salin selepas log masuk

Atribut lanjutan

// 扩展属性,ES2018新特性,可用于克隆或合并对象,浅拷贝,不包括原型
var obj2 = { ...obj3 };
Salin selepas log masuk

Sifat objek yang dibuat dengan literal boleh ditulis, boleh dikira dan boleh dikonfigurasikan secara lalai

Apa itu literal? Bagaimana untuk menggunakan literal untuk membuat objek dalam JS?

panggilan objek

panggilan atribut dalam objek:

, titik kecil ini 对象.属性名 difahami sebagai "" di dalam objek .

Satu lagi cara memanggil atribut:

, ambil perhatian bahawa atribut dalam kurungan segi empat sama mesti disertakan dalam tanda petikan, kami akan menggunakan  untuk memanggil kaedah dalam objek kemudian: 对象[&#39;属性名&#39;], ambil perhatian bahawa nama kaedah mesti diikuti oleh kurungan 对象.方法名()

var obj1 = {
    dogName: &#39;可可&#39;,
    type: &#39;阿拉斯加犬&#39;,
    age: 5 + &#39;岁&#39;,
    color: &#39;red&#39;,
    skill: function () {
        console.log(&#39;技能&#39; + &#39;:&#39; + &#39;bark&#39; + &#39;,&#39; + &#39;showFilm&#39;);
    }
}
console.log(obj1.dogName);
obj1.skill();
Salin selepas log masuk

Penjelasan: Prototaip objek

lalai kepada

. Tukar prototaip dengan mentakrifkan nilai atribut Object.prototype (hanya definisi atribut bertanda bertindih boleh digunakan). Prototaip objek akan ditetapkan kepada nilai yang diberikan hanya jika nilai yang diberikan adalah objek atau null, jika tidak, prototaip tidak akan berubah. __proto__

var obj1 = {};
Object.getPrototypeOf(obj1) === Object.prototype;	// true

var obj2 = { __proto__: null };
Object.getPrototypeOf(obj2) === null;				// true

var __proto__= {};
var obj3 = { "__proto__": __proto__ };
Object.getPrototypeOf(obj3) === __proto__;			// true
// 不使用冒号标记的属性定义,不会变更对象的原型,只是名字为__proto__的普通属性
var obj4 = { __proto__ };
Object.getPrototypeOf(obj4) === __proto__;			// false
obj4.hasOwnProperty("__proto__");					// true
Object.getPrototypeOf(obj4) === Object.prototype;	// true

var obj5 = { __proto__: "not an object or null" };
obj5.hasOwnProperty("__proto__");					// false
Object.getPrototypeOf(obj5) === Object.prototype;	// true
Salin selepas log masuk
[Cadangan berkaitan:

Tutorial pembelajaran javascript]

Atas ialah kandungan terperinci Apa itu literal? Bagaimana untuk menggunakan literal untuk membuat objek dalam JS?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:csdn.net
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan