人妻夜夜爽天天爽三区丁香花-人妻夜夜爽天天爽三-人妻夜夜爽天天爽欧美色院-人妻夜夜爽天天爽免费视频-人妻夜夜爽天天爽-人妻夜夜爽天天

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

JavaScript如何判斷對象自身為空?

admin
2025年1月6日 21:13 本文熱度 321

?

前言

如何判斷一個對象為空是我們在開發中經常會遇到的問題,今天我們來聊聊幾種經常使用的方法,以及在不同的場景下我們如何去使用。

1. JSON.stringify

JSON.stringify 方法可以使對象序列化,轉為相應的 JSON 格式。

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

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

如下示例:

const obj = {  a: undefined,  b: function() {},  c: Symbol()}
console.log(JSON.stringify(obj) === '{}')  // true

2. for in 配合 hasOwnProperty

使用 for in 對當前對象進行遍歷:

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 來實現,如下:

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 會返回對象自身可枚舉屬性組成的數組,而不會遍歷原型上的屬性。

const obj = {}Object.prototype.a = 1
console.log(Object.keys(obj).length === 0)  // true

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

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

const obj = {}Object.defineProperty(obj, 'a', {  value: 1,  enumerable: false})
console.log(obj.a)  // 1console.log(isEmptyObj(obj))  // trueconsole.log(Object.keys(obj).length === 0)  // true

4. Object.getOwnPropertyNames

使用 Object.getOwnPropertyNames 可以得到對象自身的所有屬性名組成的數組(包括不可枚舉屬性)。

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)  // trueconsole.log(JSON.stringify(obj) === '{}')  // trueconsole.log(isEmptyObj(obj))  // trueconsole.log(Object.keys(obj).length === 0)  // true

5. Object.getOwnPropertyNames 結合 Object.getOwnPropertySymbols

已知 Object.getOwnPropertyNames 唯一的缺點是不能獲取 Symbol 值作為名稱的屬性,而 Object.getOwnPropertySymbols 只能獲取由 Symbol 值作為名稱的屬性,兩者相結合是不是就可以完美解決了。我們來簡單測試一下:

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)  // falseconsole.log(getLength(obj2) === 0)  // falseconsole.log(getLength(obj3) === 0)  // falseconsole.log(getLength(obj4) === 0)  // true

經過測試,上面這種方法的確可以解決,但是比較繁瑣,那有沒有更好的方法呢?答案是有的。

6. Reflect.ownKeys

Reflect.ownKeys 方法返回一個由目標對象自身的屬性組成的數組,它的返回值等同于 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)  // falseconsole.log(Reflect.ownKeys(obj2).length === 0)  // falseconsole.log(Reflect.ownKeys(obj3).length === 0)  // falseconsole.log(Reflect.ownKeys(obj4).length === 0)  // true

總結

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


閱讀原文:原文鏈接


該文章在 2025/1/7 11:45:53 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 亚洲国产成人精品无码区在线秒播 | 亚洲成v人片在线观看福利 亚洲成v人片在线观看天 | 中文无码第3页不卡av | 国产91精选在线观看麻豆 | 日韩一区二区三区国产精品无码 | 插B内射18免费视频 插吧插吧综合网 | 亚洲精品久久无码AV片麻豆 | 久久精品视频全国免费看 | 人妻体验按摩到忍不住哀求继续 | 亚洲欧美日韩久久一区二区 | 久久精品亚洲欧美日韩久久 | 日韩精品在线看 | 69日本人xxxxxhd高清资源在线播放 | 狠狠色丁香婷婷综合最新地址 | 成人精品国产亚洲 | 国产中文字幕欧美 | 91在线激情在线观看 | 国产精品剧情原创麻豆国产 | 国产亚洲精品久久20242024 | 韩国三级无码高在线观看 | 夜夜草免费视频 | 日本日韩欧美 | 国精一二二产品无人区免费应用 | 亚洲av片不卡无码久久 | 亚洲国产另类精品 | 欧美成人动漫综合一区二区三区 | 国产成人精品热玖玖玖 | 日韩精品无码中文字幕一区二区 | 成人精品视频一区二区三区 | 人妻a级毛片无码中文字幕 人妻A片免费看 | JAPANESE少妇出轨内射 | 亚洲A无码综合A国产AV中文 | 国产成人精选视频在线观看不卡 | 美女扒开尿口让男生添 | 亚洲av无码国产精品久久 | 国产精品农村妇女一二区 | 国产不卡欧美视频在线观看 | 日韩精品国产自在久久现线拍 | 变态性折磨视频网站 | 亚洲 日韩 国产 制服 在线 | 久久精品欧美日韩精品 |