公交车上荫蒂添的好舒服的电影-公用玩物(np双xing总受)-公用小荡货芊芊-公与妇仑乱hd-攻把受做哭边走边肉楼梯play-古装一级淫片a免费播放口

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開(kāi)發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

JavaScript如何判斷對(duì)象自身為空?

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

?

前言

如何判斷一個(gè)對(duì)象為空是我們?cè)陂_(kāi)發(fā)中經(jīng)常會(huì)遇到的問(wèn)題,今天我們來(lái)聊聊幾種經(jīng)常使用的方法,以及在不同的場(chǎng)景下我們?nèi)绾稳ナ褂谩?/span>

1. JSON.stringify

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

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

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

如下示例:

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

2. for in 配合 hasOwnProperty

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

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

缺點(diǎn):for in 不能遍歷不可枚舉的屬性。

3. Object.keys

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

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

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

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

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

const obj = {}Object.defineProperty(obj, 'a', {  value: 1,  enumerable: false})
console.log(Object.getOwnPropertyNames(obj))  // [ 'a' ]

缺點(diǎn):不能獲取 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 結(jié)合 Object.getOwnPropertySymbols

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

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

經(jīng)過(guò)測(cè)試,上面這種方法的確可以解決,但是比較繁瑣,那有沒(méi)有更好的方法呢?答案是有的。

6. Reflect.ownKeys

Reflect.ownKeys 方法返回一個(gè)由目標(biāo)對(duì)象自身的屬性組成的數(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)  // falseconsole.log(Reflect.ownKeys(obj2).length === 0)  // falseconsole.log(Reflect.ownKeys(obj3).length === 0)  // falseconsole.log(Reflect.ownKeys(obj4).length === 0)  // true

總結(jié)

判斷一個(gè)對(duì)象是否為空時(shí),使用 Reflect.ownKeys 方法最為完美。


閱讀原文:原文鏈接


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

主站蜘蛛池模板: 精品无码一区二 | 国产麻豆剧传媒精品国产av | 国产精品兄妹在线观看麻豆 | 国产黄色一级片 | 国产91l在线播放 | 精品国产免费一区二区 | 国产爆乳肉感大码在线视频 | 国产大片免费观看中文字幕 | 国产成a人亚洲 | 国产成人a在线观看视频免费 | 韩国精品一区二区三区四区 | 国产成人精品一区二区秒拍 | 国产成人午夜福利在线观看视 | 精品久久久久久免费看 | 国产真人无码作爱免 | 国产波霸爆乳一区二区 | 国产人妻精品区一区二区三区 | 国产偷录视频叫床高潮 | 国产精品欧美日韩在线一区 | 精品人妻无码久久久一区二区 | 国产无套乱子伦精彩是白视频 | 国产在线成人a | 国产精品日日摸夜夜添夜夜添 | 国产不卡精品视频男人的天堂 | 成人精品一区在线 | 国产成人一区二区无码不卡在线 | 91麻豆精品国产高清在线 | 国自产精品手机在线视拍 | 91精品人妻少妇无码影院 | 成人熟女一区二区三区 | 国产精品人人爽人人做我的可爱 | 国产免费无码一区二区三区 | av片在线观看永久免费 | 国产午夜精品一区二区三 | 国产女主播在线播放一区二区 | 精品3d动漫视频一区在线观看 | 91麻豆精品国产自产在线观 | 国产在线制服丝袜国产 | 国产毛片精品高清一区二区 | 国产麻豆一区二区三区精品视频 | 国产精品一区二区手机在线观看 |