亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

6種JavaScript判斷對象自身為空的方法小結(jié)

 更新時間:2023年12月19日 08:26:32   作者:快樂的美男子  
這篇文章主要為大家詳細介紹了6種JavaScript判斷對象自身為空的方法,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下

1.JSON.stringify

JSON.stringify 方法可以使對象序列化,轉(zhuǎn)為相應(yīng)的 JSON 格式。

const obj = {};
console.log(JSON.stringify(obj) === '{}')  // true

缺點:如果存在 undefined、任意的函數(shù)以及 symbol 值,在序列化過程中會被忽略(出現(xiàn)在非數(shù)組對象的屬性值中時)或者被轉(zhuǎn)換成 null(出現(xiàn)在數(shù)組中時)。

const obj = {
  a: undefined,
  b: function() {},
  c: Symbol()
}

console.log(JSON.stringify(obj) === '{}')  // true

2. for in 配合 hasOwnProperty

使用 for in 對當(dāng)前對象進行遍歷:

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 在進行對象遍歷時,會遍歷對象原型上的屬性,而我們只希望得到其自身的屬性,這時可以使用 hasOwnProperty 來實現(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

缺點:for in 不能遍歷不可枚舉的屬性。

3. Object.keys

Object.keys 會返回對象自身可枚舉屬性組成的數(shù)組,而不會遍歷原型上的屬性。

const obj = {}
Object.prototype.a = 1

console.log(Object.keys(obj).length === 0)  // true

缺點:Object.keys 和 for in 都只能遍歷可枚舉屬性,不能遍歷不可枚舉的屬性。

我們使用 Object.defineProperty 將屬性 enumerable 設(shè)置為 false 來進行測試,示例如下:

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 可以得到對象自身的所有屬性名組成的數(shù)組(包括不可枚舉屬性)。

const obj = {}
Object.defineProperty(obj, 'a', {
  value: 1,
  enumerable: false
})

console.log(Object.getOwnPropertyNames(obj))  // [ 'a' ]

缺點:不能獲取 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 唯一的缺點是不能獲取 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 方法返回一個由目標(biāo)對象自身的屬性組成的數(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

最后

判斷一個對象是否為空時,使用 Reflect.ownKeys 方法最為完美。

到此這篇關(guān)于6種JavaScript判斷對象自身為空的方法小結(jié)的文章就介紹到這了,更多相關(guān)JavaScript判斷對象為空內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JavaScript利用正則表達式來禁止鍵盤輸入數(shù)字

    JavaScript利用正則表達式來禁止鍵盤輸入數(shù)字

    本文主要介紹了JavaScript利用正則表達式來禁止鍵盤輸入數(shù)字,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • javascript設(shè)計模式之module(模塊)模式

    javascript設(shè)計模式之module(模塊)模式

    這篇文章主要為大家詳細介紹了javascript設(shè)計模式之module(模塊)模式 ,感興趣的小伙伴們可以參考一下
    2016-08-08
  • Webpack?模塊加載動態(tài)引入機制源碼示例解析

    Webpack?模塊加載動態(tài)引入機制源碼示例解析

    這篇文章主要為大家介紹了Webpack?模塊加載動態(tài)引入機制源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • Typescript 函數(shù)重載的實現(xiàn)

    Typescript 函數(shù)重載的實現(xiàn)

    本文主要介紹了Typescript 函數(shù)重載的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • JavaScript iframe的相互操作淺析

    JavaScript iframe的相互操作淺析

    下面對iframe的所有操作都是在同一個域下進行,暫不考慮跨域調(diào)用
    2009-10-10
  • JS實現(xiàn)簡單計數(shù)器

    JS實現(xiàn)簡單計數(shù)器

    這篇文章主要為大家詳細介紹了JS實現(xiàn)簡單計數(shù)器,有加、減和零三個按鈕,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • Js數(shù)組的操作push,pop,shift,unshift等方法詳細介紹

    Js數(shù)組的操作push,pop,shift,unshift等方法詳細介紹

    js中針對數(shù)組操作的方法還是比較多的,今天突然想到來總結(jié)一下,也算是溫故而知新吧。不過不會針對每個方法進行講解,我只是選擇其中的一些來講,感興趣的朋友可以研究一下
    2012-12-12
  • 頁面加載完后自動執(zhí)行一個方法的js代碼

    頁面加載完后自動執(zhí)行一個方法的js代碼

    這篇文章主要介紹了加載完成一個頁面后自動執(zhí)行一個方法,很簡單很實用,需要的朋友可以參考下
    2014-09-09
  • JS組件Bootstrap Select2使用方法詳解

    JS組件Bootstrap Select2使用方法詳解

    這篇文章主要為大家介紹了JS組件Bootstrap Select2使用方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-01-01
  • 純js模擬div層彈性運動的方法

    純js模擬div層彈性運動的方法

    這篇文章主要介紹了純js模擬div層彈性運動的方法,涉及javascript操作div層實現(xiàn)運動的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07

最新評論