6種JavaScript判斷對(duì)象自身為空的方法小結(jié)
1.JSON.stringify
JSON.stringify
方法可以使對(duì)象序列化,轉(zhuǎn)為相應(yīng)的 JSON 格式。
const obj = {}; console.log(JSON.stringify(obj) === '{}') // true
缺點(diǎn):如果存在 undefined
、任意的函數(shù)以及 symbol 值,在序列化過程中會(huì)被忽略(出現(xiàn)在非數(shù)組對(duì)象的屬性值中時(shí))或者被轉(zhuǎn)換成 null
(出現(xiàn)在數(shù)組中時(shí))。
const obj = { a: undefined, b: function() {}, c: Symbol() } console.log(JSON.stringify(obj) === '{}') // true
2. for in 配合 hasOwnProperty
使用 for in
對(duì)當(dāng)前對(duì)象進(jìn)行遍歷:
const obj = {} Object.prototype.a = 1 function isEmptyObj(obj) { let flag = true for (let o in obj) { flag = false break } return flag } console.log(isEmptyObj(obj)) // false
由于 for in
在進(jìn)行對(duì)象遍歷時(shí),會(huì)遍歷對(duì)象原型上的屬性,而我們只希望得到其自身的屬性,這時(shí)可以使用 hasOwnProperty
來實(shí)現(xiàn),如下:
const obj = {} Object.prototype.a = 1 function isEmptyObj(obj) { let flag = true for (let o in obj) { if (obj.hasOwnProperty(o)) { flag = false break } } return flag } console.log(isEmptyObj(obj)) // true
缺點(diǎn):for in
不能遍歷不可枚舉的屬性。
3. Object.keys
Object.keys
會(huì)返回對(duì)象自身可枚舉屬性組成的數(shù)組,而不會(huì)遍歷原型上的屬性。
const obj = {} Object.prototype.a = 1 console.log(Object.keys(obj).length === 0) // true
缺點(diǎn):Object.keys
和 for in
都只能遍歷可枚舉屬性,不能遍歷不可枚舉的屬性。
我們使用 Object.defineProperty
將屬性 enumerable
設(shè)置為 false
來進(jìn)行測試,示例如下:
const obj = {} Object.defineProperty(obj, 'a', { value: 1, enumerable: false }) console.log(obj.a) // 1 console.log(isEmptyObj(obj)) // true console.log(Object.keys(obj).length === 0) // true
4. Object.getOwnPropertyNames
使用 Object.getOwnPropertyNames
可以得到對(duì)象自身的所有屬性名組成的數(shù)組(包括不可枚舉屬性)。
const obj = {} Object.defineProperty(obj, 'a', { value: 1, enumerable: false }) console.log(Object.getOwnPropertyNames(obj)) // [ 'a' ]
缺點(diǎn):不能獲取 Symbol
值作為名稱的屬性,以上的 JSON.stringify
、for in
以及 Object.keys
方法也不能獲取Symbol
值作為名稱的屬性,示例如下:
const a = Symbol() const obj = { [a]: 1 } console.log(obj) // { [Symbol()]: 1 } console.log(Object.getOwnPropertyNames(obj).length === 0) // true console.log(JSON.stringify(obj) === '{}') // true console.log(isEmptyObj(obj)) // true console.log(Object.keys(obj).length === 0) // true
5. Object.getOwnPropertyNames 結(jié)合 Object.getOwnPropertySymbols
已知 Object.getOwnPropertyNames
唯一的缺點(diǎn)是不能獲取 Symbol
值作為名稱的屬性,而 Object.getOwnPropertySymbols
只能獲取由 Symbol
值作為名稱的屬性,兩者相結(jié)合是不是就可以完美解決了。我們來簡單測試一下:
const a = Symbol() const obj1 = { [a]: 1 } const obj2 = {b: 2} const obj3 = {} Object.defineProperty(obj3, 'a', { value: 1, enumerable: false }) const obj4 = {} function getLength(obj) { return Object.getOwnPropertyNames(obj).concat(Object.getOwnPropertySymbols(obj)).length } console.log(getLength(obj1) === 0) // false console.log(getLength(obj2) === 0) // false console.log(getLength(obj3) === 0) // false console.log(getLength(obj4) === 0) // true
經(jīng)過測試,上面這種方法的確可以解決,但是比較繁瑣,那有沒有更好的方法呢?答案是有的。
6. Reflect.ownKeys
Reflect.ownKeys
方法返回一個(gè)由目標(biāo)對(duì)象自身的屬性組成的數(shù)組,它的返回值等同于 Object.getOwnPropertyNames(target).concat(Object.getOwnPropertySymbols(target))
,示例如下:
const a = Symbol() const obj1 = { [a]: 1 } const obj2 = {b: 2} const obj3 = {} Object.defineProperty(obj3, 'a', { value: 1, enumerable: false }) const obj4 = {} console.log(Reflect.ownKeys(obj1).length === 0) // false console.log(Reflect.ownKeys(obj2).length === 0) // false console.log(Reflect.ownKeys(obj3).length === 0) // false console.log(Reflect.ownKeys(obj4).length === 0) // true
最后
判斷一個(gè)對(duì)象是否為空時(shí),使用 Reflect.ownKeys
方法最為完美。
到此這篇關(guān)于6種JavaScript判斷對(duì)象自身為空的方法小結(jié)的文章就介紹到這了,更多相關(guān)JavaScript判斷對(duì)象為空內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript利用正則表達(dá)式來禁止鍵盤輸入數(shù)字
本文主要介紹了JavaScript利用正則表達(dá)式來禁止鍵盤輸入數(shù)字,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06javascript設(shè)計(jì)模式之module(模塊)模式
這篇文章主要為大家詳細(xì)介紹了javascript設(shè)計(jì)模式之module(模塊)模式 ,感興趣的小伙伴們可以參考一下2016-08-08Webpack?模塊加載動(dòng)態(tài)引入機(jī)制源碼示例解析
這篇文章主要為大家介紹了Webpack?模塊加載動(dòng)態(tài)引入機(jī)制源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09Typescript 函數(shù)重載的實(shí)現(xiàn)
本文主要介紹了Typescript 函數(shù)重載的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04Js數(shù)組的操作push,pop,shift,unshift等方法詳細(xì)介紹
js中針對(duì)數(shù)組操作的方法還是比較多的,今天突然想到來總結(jié)一下,也算是溫故而知新吧。不過不會(huì)針對(duì)每個(gè)方法進(jìn)行講解,我只是選擇其中的一些來講,感興趣的朋友可以研究一下2012-12-12頁面加載完后自動(dòng)執(zhí)行一個(gè)方法的js代碼
這篇文章主要介紹了加載完成一個(gè)頁面后自動(dòng)執(zhí)行一個(gè)方法,很簡單很實(shí)用,需要的朋友可以參考下2014-09-09