JavaScript 對(duì)象字面量講解
在編程語(yǔ)言中,字面量是一種表示值的記法。例如,"Hello, World!" 在許多語(yǔ)言中都表示一個(gè)字符串字面量(string literal ),JavaScript也不例外。以下也是JavaScript字面量的例子,如5、true、false和null,它們分別表示一個(gè)整數(shù)、兩個(gè)布爾值和一個(gè)空對(duì)象。
JavaScript還支持對(duì)象和數(shù)組字面量,允許使用一種簡(jiǎn)潔而可讀的記法來(lái)創(chuàng)建數(shù)組和對(duì)象??紤]以下語(yǔ)句,其中創(chuàng)建了一個(gè)包含兩個(gè)屬性的對(duì)象(firstName和lastName):

還可以使用一種等價(jià)的方法創(chuàng)建同樣的對(duì)象:

以上賦值語(yǔ)句的右邊是一個(gè)對(duì)象字面量(object literal)。對(duì)象字面量是一個(gè)名值對(duì)列表,每個(gè)名值對(duì)之間用逗號(hào)分隔,并用一個(gè)大括號(hào)括起。各名值對(duì)表示對(duì)象的一個(gè)屬性,名和值這兩部分之間用一個(gè)冒號(hào)分隔。要?jiǎng)?chuàng)建一個(gè)數(shù)組,可以創(chuàng)建Array對(duì)象的一個(gè)實(shí)例:

不過(guò)首選的方法是使用一個(gè)數(shù)組字面量(array literal),這是一個(gè)用逗號(hào)分隔的值列表,用中括號(hào)括起:

前面的例子展示了對(duì)象和數(shù)組字面量中可以包含其他字面量。以下是一個(gè)更復(fù)雜的示例:

賦給team變量的對(duì)象有3個(gè)屬性:name、members和count。注意,''表示空串,[]是一個(gè)空數(shù)組。甚至count屬性的值也是一個(gè)字面量,即函數(shù)字面量(function literal):

函數(shù)字面量如下構(gòu)造:前面是一個(gè)function關(guān)鍵字,后面是一個(gè)函數(shù)名(可選)和參數(shù)表。然后是函數(shù)體,包圍在大括號(hào)中。
以上已經(jīng)介紹了字面量,下面來(lái)介紹JavaScript對(duì)象記法(JavaScript Object Notation,JSON),這是一種用于描述文件和數(shù)組的記法,由JavaScript字面量的一個(gè)子集組成。JSON在Ajax開發(fā)人員中越來(lái)越流行,因?yàn)檫@種格式可以用于交換數(shù)據(jù),通常取代了XML。
=========================================================================
JavaScript對(duì)象字面量的例子(原創(chuàng))
對(duì)象字面量:
//只能添加靜態(tài)屬性和方法
var myObject={
propertyA: sha ,
propertyB: feng ,
methodA:function(){
alert(this.propertyA+ +this.propertyB);
},
methodB:function(){}
}
myObject.methodA();
//利用prototype屬性可以添加公有屬性和方法
function myConstructor2(){}; //聲明構(gòu)造函數(shù),可以使用對(duì)象字面量語(yǔ)法來(lái)向prototype屬性中添加所有公有成員
myConstructor2.prototype={
propertyA: sha ,
propertyB: feng ,
methodA:function(){
alert(this.propertyA+ +this.propertyB);
},
methodB:function(){}
}
var myconstrustor=new myConstructor2(); //聲明對(duì)象
myconstrustor.methodA();
以上就是JavaScript 對(duì)象字面量講解的全部?jī)?nèi)容,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
javascript中interval與setTimeOut的區(qū)別示例介紹
這篇文章主要介紹了javascript中interval與setTimeOut的區(qū)別,需要的朋友可以參考下2014-03-03
簡(jiǎn)單解析JavaScript中的__proto__屬性
這篇文章主要介紹了JavaScript中的__proto__屬性,對(duì)于JavaScript中所謂的對(duì)象來(lái)講,它指向?qū)ο蟮脑蚿rototype,需要的朋友可以參考下2016-05-05
Javascript學(xué)習(xí)筆記5 類和對(duì)象
首先,不得不說(shuō),我無(wú)法達(dá)到拋開類和對(duì)象的概念來(lái)看Javascript的境界,對(duì)于Javascript是否是面向?qū)ο蟮恼f(shuō)法有很多,不過(guò)我最認(rèn)同的還是Javascript是一種“基于prototype的面向?qū)ο笳Z(yǔ)言”。2010-01-01
javascript學(xué)習(xí)筆記(十三) js閉包介紹(轉(zhuǎn))
閉包(closure)是Javascript語(yǔ)言的一個(gè)難點(diǎn),也是它的特色,很多高級(jí)應(yīng)用都要依靠閉包實(shí)現(xiàn)2012-06-06
總結(jié)JavaScript設(shè)計(jì)模式編程中的享元模式使用
享元模式最適合于解決因創(chuàng)建大量類似對(duì)象而累及性能的問(wèn)題,本文將來(lái)總結(jié)JavaScript設(shè)計(jì)模式編程中的享元模式使用,包括在DOM操作時(shí)的利用示例:2016-05-05
Javascript 普通函數(shù)和構(gòu)造函數(shù)的區(qū)別
這篇文章主要介紹了Javascript 普通函數(shù)和構(gòu)造函數(shù)的區(qū)別的相關(guān)資料,需要的朋友可以參考下2016-11-11

