js判斷對(duì)象是否存在某個(gè)屬性的幾種辦法技巧
前言
在 JavaScript 開發(fā)中,判斷一個(gè)對(duì)象是否存某個(gè)屬性在是非?;A(chǔ)的操作,也是開發(fā)者經(jīng)常需要處理的問題之一。然而,繁瑣的代碼可能會(huì)讓我們感到疲憊不堪,因此這里將介紹幾種 JavaScript 小技巧,幫助你更高效地判斷對(duì)象屬性的存在性,提高代碼效率?。
?? 技巧一: 使用 hasOwnProperty 方法
hasOwnProperty 是 JavaScript 中的內(nèi)置方法,用于檢測(cè)一個(gè)對(duì)象是否擁有特定的自身屬性。如果包含,則返回 true,否則返回 false。注意,這里的“自身屬性”指的是掛在對(duì)象自身上的屬性,而不包括原型鏈上的屬性。
const person = { name: 'Tom', age: 18 }; console.log(person.hasOwnProperty('name')); // true console.log(person.hasOwnProperty('gender')); // false console.log(person.hasOwnProperty('toString')); // false 對(duì)象原型上有 toString 屬性
這種方式可以判斷一個(gè)屬性是否掛載在對(duì)象自身上,但無法判斷其是否存在于原型鏈上。
?? 技巧二:使用 in 操作符
使用 in 操作符可以判斷一個(gè)對(duì)象是否包含某個(gè)屬性,如果該屬性存在于對(duì)象自身或其原型鏈上,則返回 true,否則返回 false。
const person = { name: 'Tom', age: 18 }; console.log('name' in person); // true console.log('gender' in person); // false console.log('toString' in person); // true
這種方式可以判斷一個(gè)屬性是否存在于對(duì)象自身或其原型鏈上,但無法區(qū)分屬性是掛載在對(duì)象自身還是原型鏈上。
?? 技巧三:使用 Reflect.has 方法
Reflect.has 是 ES6 中引入的新方法,用于檢測(cè)一個(gè)對(duì)象是否包含某個(gè)屬性,與 in 操作符類似,可以同時(shí)判斷一個(gè)屬性是否存在于對(duì)象自身或原型鏈上。
const person = { name: 'Tom', age: 18 }; console.log(Reflect.has(person, 'name')); // true console.log(Reflect.has(person, 'gender')); // false console.log(Reflect.has(obj, 'toString')); // true
上面幾種方法都可以滿足我們?nèi)粘i_發(fā)中對(duì)對(duì)象屬性存在與否的判斷,如果要精確判斷屬性是在對(duì)象自身還是原型鏈上可以這樣做
const person = { name: 'Tom', age: 18 }; console.log(Object.getPrototypeOf(person).hasOwnProperty('name')); // false console.log(Object.getPrototypeOf(person).hasOwnProperty('toString')); // true
簡(jiǎn)單總結(jié)
其實(shí)實(shí)現(xiàn)對(duì)屬性的判斷還有很多方法,有些方法可能在性能上有損耗、或者判斷存在缺陷這里接不一一列舉,目前這3個(gè)方法是我日常開發(fā)中使用比較多的,推薦給大家。
到此這篇關(guān)于js判斷對(duì)象是否存在某個(gè)屬性的幾種辦法技巧的文章就介紹到這了,更多相關(guān)js判斷對(duì)象是否存在屬性內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
js+html5實(shí)現(xiàn)手機(jī)九宮格密碼解鎖功能
這篇文章主要為大家詳細(xì)介紹了js+html5實(shí)現(xiàn)手機(jī)九宮格密碼解鎖功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07微信小程序:報(bào)錯(cuò)(in promise) MiniProgramError
這篇文章主要介紹了微信小程序:報(bào)錯(cuò)(in promise) MiniProgramError,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10原生JavaScript實(shí)現(xiàn)remove()和recover()功能示例
這篇文章主要介紹了原生JavaScript實(shí)現(xiàn)remove()和recover()功能,結(jié)合實(shí)例形式分析了javascript實(shí)現(xiàn)類似jQueryremove()和recover()功能的自定義函數(shù),需要的朋友可以參考下2018-07-07小程序Scroll-view上拉滾動(dòng)刷新數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了小程序Scroll-view上拉滾動(dòng)刷新數(shù)據(jù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-06-06JS實(shí)現(xiàn)頁面超時(shí)后自動(dòng)跳轉(zhuǎn)到登陸頁面
這篇文章主要介紹了JS實(shí)現(xiàn)頁面超時(shí)后自動(dòng)跳轉(zhuǎn)到登陸頁面,需要的朋友可以參考下2015-01-01JavaScript運(yùn)行過程中的“預(yù)編譯階段”和“執(zhí)行階段”
這篇文章主要介紹了JavaScript運(yùn)行過程中的“預(yù)編譯階段”和“執(zhí)行階段”的相關(guān)資料,需要的朋友可以參考下2015-12-12JS利用時(shí)間戳倒計(jì)時(shí)的實(shí)現(xiàn)示例
這篇文章主要介紹了JS利用時(shí)間戳倒計(jì)時(shí)的實(shí)現(xiàn)示例,本文將提供代碼示例和詳細(xì)的步驟,幫助你實(shí)現(xiàn)一個(gè)簡(jiǎn)單而實(shí)用的時(shí)間戳倒計(jì)時(shí),感興趣的可以了解一下2023-12-12