使用JavaScript怎么判斷對(duì)象中是否有某屬性?相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。
為聶榮等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及聶榮網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、聶榮網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!一、點(diǎn)( . )或者方括號(hào)( [ ] )
通過點(diǎn)或者方括號(hào)可以獲取對(duì)象的屬性值,如果對(duì)象上不存在該屬性,則會(huì)返回undefined。當(dāng)然,這里的“不存在”指的是對(duì)象自身和原型鏈上都不存在,如果原型鏈有該屬性,則會(huì)返回原型鏈上的屬性值。
// 創(chuàng)建對(duì)象 let test = {name : 'lei'} // 獲取對(duì)象的自身的屬性 test.name //"lei" test["name"] //"lei" // 獲取不存在的屬性 test.age //undefined // 獲取原型上的屬性 test["toString"] //toString() { [native code] } // 新增一個(gè)值為undefined的屬性 test.un = undefined test.un //undefined 不能用在屬性值存在,但可能為 undefined的場(chǎng)景
所以,我們可以根據(jù) Obj.x !== undefined
的返回值 來判斷Obj是否有x屬性。
這種方式很簡單方便,局限性就是:不能用在x的屬性值存在,但可能為 undefined的場(chǎng)景。 in運(yùn)算符可以解決這個(gè)問題
二、 in 運(yùn)算符
MDN 上對(duì)in運(yùn)算符的介紹:如果指定的屬性在指定的對(duì)象或其原型鏈中,則in 運(yùn)算符返回true。
'name' in test //true 'un' in test //true 'toString' in test //true 'age' in test //false
示例中可以看出,值為undefined的屬性也可正常判斷。
這種方式的局限性就是無法區(qū)分自身和原型鏈上的屬性,在只需要判斷自身屬性是否存在時(shí),這種方式就不適用了。這時(shí)需要hasOwnProperty()
三、hasOwnProperty()
test.hasOwnProperty('name') //true 自身屬性 test.hasOwnProperty('age') //false 不存在 test.hasOwnProperty('toString') //false 原型鏈上屬性
1.JavaScript主要用來向HTML頁面添加交互行為。 2.JavaScript可以直接嵌入到HTML頁面,但寫成單獨(dú)的js文件有利于結(jié)構(gòu)和行為的分離。 3.JavaScript具有跨平臺(tái)特性,在絕大多數(shù)瀏覽器的支持下,可以在多種平臺(tái)下運(yùn)行。
看完上述內(nèi)容,你們掌握使用JavaScript怎么判斷對(duì)象中是否有某屬性的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道,感謝各位的閱讀!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。