關(guān)于JavaScript對(duì)象的動(dòng)態(tài)選擇及遍歷對(duì)象
更新時(shí)間:2014年03月10日 11:24:30 作者:
本文為大家介紹下JavaScript對(duì)象的兩點(diǎn):動(dòng)態(tài)選擇方法及屬性、遍歷對(duì)象屬性和方法,需要的朋友可以參考下
(一)動(dòng)態(tài)選擇方法及屬性
在實(shí)際工作中,我們經(jīng)常會(huì)遇到這種情況:根據(jù)某個(gè)條件來(lái)調(diào)用兩個(gè)方法[1]中的一個(gè),或是在兩個(gè)屬性[2]中的一個(gè)上面進(jìn)行讀寫(xiě)操作。下面的代碼展示了這種情形:
if (condition) {
myObj.method1(someArg);
} else {
myObj.method2(someArg);
}
JavaScript提供了一種簡(jiǎn)單的語(yǔ)法,即使用方括號(hào)操作符([])來(lái)動(dòng)態(tài)地選擇方法和屬性。正如下面的代碼所示,JavaScript有兩種等價(jià)的成員訪問(wèn)語(yǔ)法(這個(gè)特征在動(dòng)態(tài)語(yǔ)言里很常見(jiàn)):
obj[expressionResultingInMembername] == obj.memberName
如果你曾用整數(shù)下標(biāo)來(lái)訪問(wèn)數(shù)組中的某個(gè)元素,那你已經(jīng)開(kāi)始用方括號(hào)操作符來(lái)進(jìn)行動(dòng)態(tài)成員選擇了。這是因?yàn)椋瑪?shù)組對(duì)象本身就包含以數(shù)字下標(biāo)命名的屬性(以及l(fā)ength屬性)。不過(guò),JavaScript并不允許你使用點(diǎn)操作符(.)直接訪問(wèn)這些屬性,因此myArray.0在語(yǔ)法上是非法的(太遺憾了,這本來(lái)是個(gè)挺酷的語(yǔ)法)。
為什么方括號(hào)操作符比點(diǎn)操作符表示法更強(qiáng)大呢?這是因?yàn)槟憧梢栽诜嚼ㄌ?hào)中使用任何代表成員名稱(chēng)的內(nèi)容來(lái)訪問(wèn)對(duì)象的成員。這些內(nèi)容包括字面量、保存著成員名稱(chēng)的變量、名稱(chēng)組合(多數(shù)情況下是字符串的拼接)以及用三元操作符(condition ? valueIfTrue : valueIfFalse)實(shí)現(xiàn)的快速if/then選擇。所有的這些內(nèi)容都會(huì)被處理成一個(gè)字符串,然后JavaScript會(huì)用這個(gè)字符串來(lái)尋找對(duì)應(yīng)的成員。
由于JavaScript中的函數(shù)本身也是對(duì)象,所以它可以像其他值一樣被引用。如果一個(gè)表達(dá)式的結(jié)果是函數(shù),你可以直接用括號(hào)操作符調(diào)用它,就像你直接用函數(shù)名稱(chēng)調(diào)用函數(shù)一樣。
需要注意的是,如果你在向方法傳遞的參數(shù)上大量使用此類(lèi)技巧,混亂的括號(hào)有可能會(huì)使代碼變得難以閱讀,此時(shí)使用常規(guī)的if/else結(jié)構(gòu)更加明智。
(二)JavaScript遍歷對(duì)象屬性和方法
JavaScript 使用 for in 語(yǔ)句來(lái)遍歷對(duì)象的屬性和方法。for in 語(yǔ)句循環(huán)遍歷 JavaScript 對(duì)象,每循環(huán)一次,都會(huì)取得對(duì)象的一個(gè)屬性或方法。
語(yǔ)法:
for(valueName in ObjectName){
// 代碼
}
其中,valueName 是變量名,保存著屬性或方法的名稱(chēng),每次循環(huán),valueName 的值都會(huì)改變。
在實(shí)際工作中,我們經(jīng)常會(huì)遇到這種情況:根據(jù)某個(gè)條件來(lái)調(diào)用兩個(gè)方法[1]中的一個(gè),或是在兩個(gè)屬性[2]中的一個(gè)上面進(jìn)行讀寫(xiě)操作。下面的代碼展示了這種情形:
復(fù)制代碼 代碼如下:
if (condition) {
myObj.method1(someArg);
} else {
myObj.method2(someArg);
}
JavaScript提供了一種簡(jiǎn)單的語(yǔ)法,即使用方括號(hào)操作符([])來(lái)動(dòng)態(tài)地選擇方法和屬性。正如下面的代碼所示,JavaScript有兩種等價(jià)的成員訪問(wèn)語(yǔ)法(這個(gè)特征在動(dòng)態(tài)語(yǔ)言里很常見(jiàn)):
obj[expressionResultingInMembername] == obj.memberName
如果你曾用整數(shù)下標(biāo)來(lái)訪問(wèn)數(shù)組中的某個(gè)元素,那你已經(jīng)開(kāi)始用方括號(hào)操作符來(lái)進(jìn)行動(dòng)態(tài)成員選擇了。這是因?yàn)椋瑪?shù)組對(duì)象本身就包含以數(shù)字下標(biāo)命名的屬性(以及l(fā)ength屬性)。不過(guò),JavaScript并不允許你使用點(diǎn)操作符(.)直接訪問(wèn)這些屬性,因此myArray.0在語(yǔ)法上是非法的(太遺憾了,這本來(lái)是個(gè)挺酷的語(yǔ)法)。
為什么方括號(hào)操作符比點(diǎn)操作符表示法更強(qiáng)大呢?這是因?yàn)槟憧梢栽诜嚼ㄌ?hào)中使用任何代表成員名稱(chēng)的內(nèi)容來(lái)訪問(wèn)對(duì)象的成員。這些內(nèi)容包括字面量、保存著成員名稱(chēng)的變量、名稱(chēng)組合(多數(shù)情況下是字符串的拼接)以及用三元操作符(condition ? valueIfTrue : valueIfFalse)實(shí)現(xiàn)的快速if/then選擇。所有的這些內(nèi)容都會(huì)被處理成一個(gè)字符串,然后JavaScript會(huì)用這個(gè)字符串來(lái)尋找對(duì)應(yīng)的成員。
由于JavaScript中的函數(shù)本身也是對(duì)象,所以它可以像其他值一樣被引用。如果一個(gè)表達(dá)式的結(jié)果是函數(shù),你可以直接用括號(hào)操作符調(diào)用它,就像你直接用函數(shù)名稱(chēng)調(diào)用函數(shù)一樣。
需要注意的是,如果你在向方法傳遞的參數(shù)上大量使用此類(lèi)技巧,混亂的括號(hào)有可能會(huì)使代碼變得難以閱讀,此時(shí)使用常規(guī)的if/else結(jié)構(gòu)更加明智。
(二)JavaScript遍歷對(duì)象屬性和方法
JavaScript 使用 for in 語(yǔ)句來(lái)遍歷對(duì)象的屬性和方法。for in 語(yǔ)句循環(huán)遍歷 JavaScript 對(duì)象,每循環(huán)一次,都會(huì)取得對(duì)象的一個(gè)屬性或方法。
語(yǔ)法:
復(fù)制代碼 代碼如下:
for(valueName in ObjectName){
// 代碼
}
其中,valueName 是變量名,保存著屬性或方法的名稱(chēng),每次循環(huán),valueName 的值都會(huì)改變。
相關(guān)文章
如何用uni-app實(shí)現(xiàn)頂部導(dǎo)航欄顯示按鈕和搜索框
本文介紹了如何用uni-app實(shí)現(xiàn)頂部導(dǎo)航欄顯示按鈕和搜索框,感興趣的同學(xué),可以參考下,并且試驗(yàn)一下。2021-06-06EditPlus 正則表達(dá)式 實(shí)戰(zhàn)(3)
這篇文章主要介紹了EditPlus 正則表達(dá)式 實(shí)戰(zhàn)(3)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12JavaScript 語(yǔ)言精粹學(xué)習(xí)筆記
JavaScript建立在一些非常好的想法和少數(shù)非常壞的想法之上。2009-08-08怎樣用Javascript實(shí)現(xiàn)函數(shù)柯里化與反柯里化
這篇文章主要介紹了怎樣用Javascript實(shí)現(xiàn)函數(shù)柯里化與反柯里化,想了解函數(shù)柯里化的同學(xué),可以參考下2021-04-04JS獲取scrollHeight問(wèn)題想到的標(biāo)準(zhǔn)問(wèn)題
如果沒(méi)有文檔聲明可以用 document.body.scrollHeight,如果有文檔聲明必須用 document.documentElement.scrollHeight關(guān)于這方面的東西2007-05-05微信小程序錯(cuò)誤this.setData報(bào)錯(cuò)及解決過(guò)程
這篇文章主要介紹了微信小程序錯(cuò)誤this.setData報(bào)錯(cuò)及解決過(guò)程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09JS+CSS實(shí)現(xiàn)可拖動(dòng)的彈出提示框
這篇文章主要介紹了JS+CSS實(shí)現(xiàn)可拖動(dòng)的彈出提示框,涉及針對(duì)鼠標(biāo)事件及html元素的操作技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-02-02