JavaScript 是一種廣泛使用的程式語言,它具有動態性和靈活性。而在 JavaScript 中,物件是其最強大、最常用的語言結構之一。本文將介紹 JavaScript 物件的用法、特性和常見應用。
一、JavaScript 物件簡介
JavaScript 物件是一種資料類型,用於封裝多個屬性並組成一組資料。其語法可以使用物件字面量、建構子或 Object.create() 方法來建立。
物件字面量法是 JavaScript 中建立物件最簡單、最常用的方法。其語法如下:
var obj = { propertyName1: value1, propertyName2: value2, ... propertyNameN: valueN };
其中,propertyName
為屬性名,value
為屬性值。可以認為物件字面量法是一種類似 JSON 的創建物件方式。
建構函式法是透過定義一個建構函式來建立物件的方法。其語法如下:
function Object(propertyName1, propertyName2, ..., propertyNameN) { this.propertyName1 = propertyName1; this.propertyName2 = propertyName2; ... this.propertyNameN = propertyNameN; } var obj = new Object(value1, value2, ..., valueN);
其中,this
關鍵字表示目前對象,並透過參數傳入屬性值。
Object.create() 是一種建立物件的方法,它可以用來建立新物件並指定該物件的原型對象。其語法如下:
var obj = Object.create(proto, [propertiesObject])
其中,proto
表示原型對象,propertiesObject
表示要新增到對象的屬性及其屬性值。
二、JavaScript 物件特性
JavaScript 物件有以下幾個特性:
var obj = {name: "Tom", age: 20}; console.log(obj.name); // 输出:"Tom"
var obj = { name: "Tom", age: 20, sayHello: function() { console.log("Hello, my name is " + this.name + ", I am " + this.age + " years old."); } }; obj.sayHello(); // 输出:"Hello, my name is Tom, I am 20 years old."
var parent = {x: 1}; var child = Object.create(parent); console.log(child.x); // 输出:1
var arrOfObj = [ {name: "Tom", age: 20}, {name: "Jerry", age: 21}, {name: "Mickey", age: 22} ];
. 和
[] 可以存取和修改物件屬性。
var obj = {name: "Tom", age: 20}; console.log(obj.name); // 输出:"Tom" obj.age = 21; console.log(obj["age"]); // 输出:21
function printObjInfo(obj) { console.log("Object name is " + obj.name + ", and age is " + obj.age); } var obj = {name: "Tom", age: 20}; printObjInfo(obj); // 输出:"Object name is Tom, and age is 20"
function Person(name, age) { this.name = name; this.age = age; } Person.prototype.sayHello = function() { console.log("Hello, my name is " + this.name + ", I am " + this.age + " years old."); }; function Student(name, age, grade) { Person.call(this, name, age); this.grade = grade; } Student.prototype = Object.create(Person.prototype); Student.prototype.constructor = Student; Student.prototype.study = function() { console.log(this.name + " is studying in grade " + this.grade); }; var stu = new Student("Tom", 20, 3); stu.sayHello(); // 输出:"Hello, my name is Tom, I am 20 years old." stu.study(); // 输出:"Tom is studying in grade 3"
以上是javascript 物件用法的詳細內容。更多資訊請關注PHP中文網其他相關文章!