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