javascript如何判斷Object是空物件

wdapp發表於2020-03-10

判斷一個物件是否為空物件,本文給出三種判斷方法:

1.最常見的思路,for...in... 遍歷屬性,為真則為“非空陣列”;否則為“空陣列”

for (var i in obj) { // 如果不為空,則會執行到這一步,返回true
    return true
}
return false // 如果為空,返回false
複製程式碼

2.通過 JSON 自帶的 stringify() 方法來判斷:

JSON.stringify() 方法用於將 JavaScript 值轉換為 JSON 字串。

if (JSON.stringify(data) === '{}') {
    return false // 如果為空,返回false
}
return true // 如果不為空,則會執行到這一步,返回true
複製程式碼

這裡需要注意為什麼不用 toString(),因為它返回的不是我們需要的。

var a = {}
a.toString() // "[object Object]"
複製程式碼

3.ES6 新增的方法 Object.keys():

Object.keys() 方法會返回一個由一個給定物件的自身可列舉屬性組成的陣列。

如果我們的物件為空,他會返回一個空陣列,如下:

var a = {}
Object.keys(a) // []
複製程式碼

我們可以依靠Object.keys()這個方法通過判斷它的長度來知道它是否為空。

if (Object.keys(object).length === 0) {
    return false // 如果為空,返回false
}
return true // 如果不為空,則會執行到這一步,返回true
複製程式碼

補充

function checkNullObj (obj) {
    if (Object.keys(obj).length === 0) {
        return false // 如果為空,返回false
    }
    return true // 如果不為空,則會執行到這一步,返回true
}
複製程式碼

function checkNullObj (obj) {
    return Object.keys(obj).length === 0
}
複製程式碼

相關文章