如何檢查一個對象是否爲空

20190401232110.png

⭐️ 更多前端技術和知識點,搜索訂閱號 JS 菌 訂閱

檢查一個數組爲空很容易,直接調用 length 方法便可,那麼如何檢查一個對象是否爲空呢 ❓前端

這裏的空指的是對象沒有自有屬性

假設這裏有兩個對象,一個是 obj 一個是 anotherObj數組

let obj1 = {
    name: 'oli',
    child: {
        name: 'oliver'
    }
}

let obj2 = {
    [Symbol('name')]: 'alice'
}

let obj3 = Object.defineProperty({}, 'name', {
    value: 'alice',
    enumerable: false
})

let obj4 = Object.create(null)

// 咱們須要一個函數,判斷是否不含自有屬性

isEmpty(obj1) // false
isEmpty(obj2) // false
isEmpty(obj3) // false
isEmpty(obj4) // true
❗️想了半天查看對象是否有 Symbol 屬性只能使用 getOwnPropertySymbols 方法,若是還有更好的方法歡迎留言

方法一:遍歷

for-in 遍歷,並經過 hasOwnProperty 方法確認是否存在某個 key 這種方法不可以遍歷到 enumerable 爲 false 的屬性函數

const isEmptyObj = object => {
    if (!!Object.getOwnPropertySymbols(object).length) {
        return false
    }
    for (const key in object) {
        if (object.hasOwnProperty(key)) {
            return false
        }
    }
    return true
}

方法二:keys 方法

使用 Object 靜態方法 keys 而後判斷 length 便可,keys 返回的是自身可枚舉屬性,所以一樣的不可遍歷到 enumerable 爲 false 的屬性spa

const isEmptyObj = object => {
    if (!!Object.getOwnPropertySymbols(object).length) {
        return false
    }
    if (Object.keys(object).length) {
        return false
    }
    return true
}

方法三:JSON 方法

使用 JSON Stringify 方法將對象轉爲字符串,與字符串 '{}' 對比,一樣該方法沒法獲取到不可遍歷屬性code

const isEmptyObj = object => {
    if (!!Object.getOwnPropertySymbols(object).length) {
        return false
    }
    return JSON.stringify(object) === '{}'
}

方法四:getOwnPropertyNames 方法

使用 Object 的 getOwnPropertyNames 方法,獲取全部屬性名,這樣就算是不可枚舉屬性依然可以獲取到,算是比較 ok 的方法。對象

const isEmptyObj = object => {
    if (!!Object.getOwnPropertySymbols(object).length) {
        return false
    }
    if (!!Object.getOwnPropertyNames(object).length) {
        return false
    }
    return true
}

20190401230821.png

簡化版:blog

const isEmptyObj = object => !Object.getOwnPropertySymbols(object).length && !Object.getOwnPropertyNames(object).length

JS 菌公衆帳號

若是有更好的方法歡迎留言

請關注個人訂閱號,不按期推送有關 JS 的技術文章,只談技術不談八卦 😊rem

EOF字符串

相關文章
相關標籤/搜索