⭐️ 更多前端技術和知識點,搜索訂閱號
JS 菌
訂閱前端
檢查一個數組爲空很容易,直接調用 length 方法便可,那麼如何檢查一個對象是否爲空呢 ❓數組
這裏的空指的是對象沒有自有屬性markdown
假設這裏有兩個對象,一個是 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 方法,若是還有更好的方法歡迎留言spa
for-in 遍歷,並經過 hasOwnProperty 方法確認是否存在某個 key 這種方法不可以遍歷到 enumerable 爲 false 的屬性code
const isEmptyObj = object => { if (!!Object.getOwnPropertySymbols(object).length) { return false } for (const key in object) { if (object.hasOwnProperty(key)) { return false } } return true } 複製代碼
使用 Object 靜態方法 keys 而後判斷 length 便可,keys 返回的是自身可枚舉屬性,所以一樣的不可遍歷到 enumerable 爲 false 的屬性orm
const isEmptyObj = object => { if (!!Object.getOwnPropertySymbols(object).length) { return false } if (Object.keys(object).length) { return false } return true } 複製代碼
使用 JSON Stringify 方法將對象轉爲字符串,與字符串 '{}' 對比,一樣該方法沒法獲取到不可遍歷屬性對象
const isEmptyObj = object => { if (!!Object.getOwnPropertySymbols(object).length) { return false } return JSON.stringify(object) === '{}' } 複製代碼
使用 Object 的 getOwnPropertyNames 方法,獲取全部屬性名,這樣就算是不可枚舉屬性依然可以獲取到,算是比較 ok 的方法。字符串
const isEmptyObj = object => { if (!!Object.getOwnPropertySymbols(object).length) { return false } if (!!Object.getOwnPropertyNames(object).length) { return false } return true } 複製代碼
簡化版:get
const isEmptyObj = object => !Object.getOwnPropertySymbols(object).length && !Object.getOwnPropertyNames(object).length 複製代碼
若是有更好的方法歡迎留言
請關注個人訂閱號,不按期推送有關 JS 的技術文章,只談技術不談八卦 😊
EOF