欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

前端判斷對(duì)象為空的6種方法舉例

 更新時(shí)間:2024年05月20日 11:57:51   作者:じòぴé南冸じょうげん  
在前端中可以使用多種方法來(lái)判斷一個(gè)對(duì)象是否為空,這篇文章主要給大家介紹了關(guān)于前端判斷對(duì)象為空的6種方法,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

當(dāng)前端需要判斷一個(gè)對(duì)象是否為空時(shí),有多種方法可以實(shí)現(xiàn)。

下面列出了六種常見(jiàn)的方法,并提供了相應(yīng)的例子和解釋:

1.使用Object.keys()方法:

主要是獲取對(duì)象的鍵名,將對(duì)象的屬性轉(zhuǎn)換成數(shù)組,通過(guò)是否存在鍵名(數(shù)組的長(zhǎng)度是否為0)而判斷是否為空

function isEmptyObject(obj) {
  return Object.keys(obj).length === 0;
}

const obj1 = {};
console.log(isEmptyObject(obj1)); // true

const obj2 = { name: 'juny long', age: 18};
console.log(isEmptyObject(obj2)); // false

2.使用for…in循環(huán):

使用for…in循環(huán)遍歷對(duì)象屬性,并使用obj.hasOwnProperty()檢查屬性是否屬于對(duì)象本身,如果存在任何屬性,則返回false,否則返回true。

function isEmptyObject(obj) {
  for (let key in obj) {
    if (obj.hasOwnProperty(key))
      return false;
  }
  return true;
}

const obj1 = {};
console.log(isEmptyObject(obj1)); // true

const obj2 = { name: 'juny long', age: 18};
console.log(isEmptyObject(obj2)); // false

3.使用JSON.stringify()方法:

JSON.stringify() 是將一個(gè)JavaScript對(duì)象或值轉(zhuǎn)換為JSON格式字符串,如果最終只得到一個(gè){},就說(shuō)明他是一個(gè)空對(duì)象

function isEmptyObject(obj) {
  return JSON.stringify(obj) === '{}';
}

const obj1 = {};
console.log(isEmptyObject(obj1)); // true

const obj2 = { name: 'juny long', age: 18 };
console.log(isEmptyObject(obj2)); // false

 JSON.parse 和 JSON.stringify

在ES5中,增加了一個(gè)JSON對(duì)象,專門用來(lái)處理JSON格式的數(shù)據(jù)。
JSON是一個(gè)對(duì)象,但只有兩個(gè)方法:parse 和 stringify,不能作為構(gòu)造函數(shù),也無(wú)屬性

1.JSON.stringify() 語(yǔ)法為:

(返回指定數(shù)據(jù)的JSON格式字符串)

JSON.stringify(value[, replacer [, space]])
  • value:將要序列化成 一個(gè)JSON字符串的JavaScript對(duì)象或值。
  • replacer 可選,用于處理將要序列化的值。
  • space 可選,指定縮進(jìn)用的空白字符串,用于美化輸出。

2.JSON.parse() 語(yǔ)法為:

(用來(lái)解析JSON字符串得到對(duì)應(yīng)的JavaScript值或?qū)ο螅?/p>

JSON.parse(text[, reviver])
  • text:要被解析成的字符串。
    如果傳入數(shù)字則會(huì)轉(zhuǎn)換成十進(jìn)制數(shù)字輸出。
    如果傳入布爾值則直接輸出。
    如果傳入null則輸出null。
    不支持其他類型的值,否則報(bào)錯(cuò)。
  • reviver: 可選,轉(zhuǎn)換器, 可以用來(lái)修改解析生成的原始值。
  • 返回值 JavaScript對(duì)象/值, 對(duì)應(yīng)給定JSON文本的對(duì)象/值。

在解析JSON字符串的時(shí)候,需要注意到JSON格式的一些規(guī)范,不然就容易報(bào)錯(cuò)。

4.ES6的Object.getOwnPropertyNames()方法:

這種方法通過(guò)Object.getOwnPropertyNames()方法獲取對(duì)象的所有屬性,然后判斷屬性數(shù)組的長(zhǎng)度是否為0來(lái)確定對(duì)象是否為空。

和上面講到的Object.keys()相似哦,下面將會(huì)簡(jiǎn)單講到其區(qū)別

function isEmptyObject(obj) {
  return Object.getOwnPropertyNames(obj).length === 0;
}

const obj1 = {};
console.log(isEmptyObject(obj1)); // true

const obj2 = { name: 'juny long', age: 18 };
console.log(isEmptyObject(obj2)); // false

Object.getOwnPropertyNames()與Object.keys()的區(qū)別:

相同點(diǎn):

功能是一樣的,一般是用來(lái)獲取一個(gè)JSON對(duì)象中所有屬性

差異點(diǎn):

Object.getOwnPropertyNames:返回的是對(duì)象所有自己的屬性,

Object.keys(obj):返回的是所有可枚舉屬性,也就是屬性下的enumerable: false

5.第三方庫(kù)

5.1使用lodash庫(kù)的isEmpty()方法:

檢查 value 是否為一個(gè)空對(duì)象,集合,映射或者set。 判斷的依據(jù)是除非是有枚舉屬性的對(duì)象,length 大于 0 的 arguments object, array, string 或類jquery選擇器。

對(duì)象如果被認(rèn)為為空,那么他們沒(méi)有自己的可枚舉屬性的對(duì)象。

這種方法使用lodash庫(kù)中的isEmpty()方法,直接判斷對(duì)象是否為空。

返回值:

(boolean): 如果 value 為空,那么返回 true,否則返回 false

const _ = require('lodash');

const obj1 = {};
console.log(_.isEmpty(obj1)); // true

const obj2 = { name: 'juny long', age: 18 };
console.log(_.isEmpty(obj2)); // false

5.2.使用underscore庫(kù)的isEmpty()方法:

這種方法使用underscore庫(kù)中的isEmpty()方法,直接判斷,和lodash庫(kù)的擦不多。

const _ = require('underscore');

const obj1 = {};
console.log(_.isEmpty(obj1)); // true

const obj2 = { name: 'juny long', age: 18 };
console.log(_.isEmpty(obj2)); // false

總結(jié)

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

相關(guān)文章

  • 學(xué)習(xí)JS中的DOM節(jié)點(diǎn)以及操作

    學(xué)習(xí)JS中的DOM節(jié)點(diǎn)以及操作

    本篇文章給大家整理了關(guān)于JS中DOM節(jié)點(diǎn)的相關(guān)知識(shí)點(diǎn)以及代碼實(shí)例,有興趣的朋友可以跟著學(xué)習(xí)下。
    2018-04-04
  • 基于BootStrap multiselect.js實(shí)現(xiàn)的下拉框聯(lián)動(dòng)效果

    基于BootStrap multiselect.js實(shí)現(xiàn)的下拉框聯(lián)動(dòng)效果

    當(dāng)option特別多時(shí),一般的下拉框選擇起來(lái)就有點(diǎn)力不從心了,所以使用multiselect是個(gè)很好的選擇。在網(wǎng)上找了半天找到了解決方案,具體實(shí)現(xiàn)代碼大家參考下本文吧
    2017-07-07
  • 細(xì)說(shuō)webpack6 Babel的使用詳解

    細(xì)說(shuō)webpack6 Babel的使用詳解

    這篇文章主要介紹了細(xì)說(shuō)webpack6 Babel的使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • js實(shí)現(xiàn)復(fù)選框的全選和取消全選效果

    js實(shí)現(xiàn)復(fù)選框的全選和取消全選效果

    在很多網(wǎng)站都有這樣的功能,當(dāng)點(diǎn)擊一個(gè)全選按鈕之后,所有的復(fù)選框都會(huì)被選中,再點(diǎn)擊之后會(huì)取消全選,功能非常的人性化,可以省卻很多人力,本文將簡(jiǎn)單介紹一下JS如何實(shí)現(xiàn)此功能
    2017-01-01
  • 老生常談Javascript中的原型和this指針

    老生常談Javascript中的原型和this指針

    下面小編就為大家?guī)?lái)一篇老生常談Javascript中的原型和this指針。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧,祝大家游戲愉快哦
    2016-10-10
  • 微信小程序自動(dòng)化部署的全過(guò)程

    微信小程序自動(dòng)化部署的全過(guò)程

    由于微信小程序需要在微信小程序助手上發(fā)布,比較麻煩,可以配置CI 自動(dòng)化的發(fā)布,下面這篇文章主要給大家介紹了關(guān)于微信小程序自動(dòng)化部署的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • 一款好用的移動(dòng)端滾動(dòng)插件BetterScroll

    一款好用的移動(dòng)端滾動(dòng)插件BetterScroll

    BetterScroll 是一款重點(diǎn)解決移動(dòng)端各種滾動(dòng)場(chǎng)景需求的開(kāi)源插件,用于滾動(dòng)列表、選擇器、輪播圖、索引列表、開(kāi)屏引導(dǎo)等應(yīng)用場(chǎng)景,感興趣的一起來(lái)了解一下
    2021-09-09
  • javascript 實(shí)現(xiàn) 秒殺,團(tuán)購(gòu) 倒計(jì)時(shí)展示的記錄 分享

    javascript 實(shí)現(xiàn) 秒殺,團(tuán)購(gòu) 倒計(jì)時(shí)展示的記錄 分享

    這篇文章介紹了javascript 實(shí)現(xiàn) 秒殺,團(tuán)購(gòu) 倒計(jì)時(shí)展示的記錄方法,有需要的朋友可以參考一下
    2013-07-07
  • js網(wǎng)頁(yè)中隨意拖動(dòng)的小方塊實(shí)現(xiàn)代碼

    js網(wǎng)頁(yè)中隨意拖動(dòng)的小方塊實(shí)現(xiàn)代碼

    用CSS和JS制作的在網(wǎng)頁(yè)中可以隨意拖動(dòng)的小方塊。
    2008-08-08
  • Asp.Net之JS生成分頁(yè)條的方法

    Asp.Net之JS生成分頁(yè)條的方法

    下面小編就為大家?guī)?lái)一篇Asp.Net之JS生成分頁(yè)條的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-11-11

最新評(píng)論