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

原生javascript中檢查對(duì)象是否為空示例實(shí)現(xiàn)

 更新時(shí)間:2021年11月25日 15:04:22   作者:廈門在乎科技  
這篇文章主要為大家介紹了原生javascript中檢查對(duì)象是否為空示例實(shí)現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

下面的代碼片段,用于檢查對(duì)象是否為空。 對(duì)于較新的瀏覽器,你可以使用 ES6 的 “Object.keys”。對(duì)于較舊的瀏覽器,可以安裝Lodash庫(kù)并使用其“ isEmpty”方法。

const empty = {}; 
/* -------------------------
  較新的瀏覽器
----------------------------*/
Object.keys(empty).length === 0 && empty.constructor === Object
// true 
/* -------------------------
  老版本的瀏覽器可以使用 Lodash
----------------------------*/
_.isEmpty(empty)
// true

什么是原生 JavaScript

原生 JavaScript 指的是不使用框架或庫(kù)。 它只是常規(guī)的普通 JavaScript,沒有使用LodashjQuery之類的庫(kù)。

A.在較新的瀏覽器中檢查空對(duì)象

我們可以使用內(nèi)置的Object.keys方法檢查空對(duì)象。

const empty = {}; 
Object.keys(empty).length === 0 && empty.constructor === object;

為什么我們需要額外的constructor?檢查?

你可能想知道為什么我們需要對(duì)?constructor?進(jìn)行檢查。 它是為了覆蓋包裝器實(shí)例。在JavaScript中,我們有9個(gè)內(nèi)置的構(gòu)造函數(shù)。

new Object();
new String();
new Number();
new Boolean();
new Array();
new RegExp();
new Function();
new Date();

這里,我們可以使用new Object()創(chuàng)建一個(gè)空對(duì)象。

const obj = new Object(); 
Object.keys(obj).length === 0; // true

因此,僅使用Object.keys,當(dāng)對(duì)象為空時(shí),它的確會(huì)返回true。 但是,當(dāng)我們使用其他構(gòu)造函數(shù)創(chuàng)建新的對(duì)象實(shí)例時(shí)會(huì)發(fā)生什么。

function badEmptyCheck(value) {
  return Object.keys(value).length === 0;
} 
badEmptyCheck(new String());    // true 
badEmptyCheck(new Number());    // true 
badEmptyCheck(new Boolean());   // true 
badEmptyCheck(new Array());     // true 
badEmptyCheck(new RegExp());    // true 
badEmptyCheck(new Function());  // true 
badEmptyCheck(new Date());      // true 

通過檢查 constructor 解決誤報(bào)

通過添加構(gòu)造函數(shù)檢查來(lái)糾正這個(gè)錯(cuò)誤。

function goodEmptyCheck(value) {
  Object.keys(value).length === 0
    && value.constructor === Object; //  constructor check
}
goodEmptyCheck(new String());   // false 
goodEmptyCheck(new Number());   // false 
goodEmptyCheck(new Boolean());  // false 
goodEmptyCheck(new Array());    // false 
goodEmptyCheck(new RegExp());   // false 
goodEmptyCheck(new Function()); // false 
goodEmptyCheck(new Date());     // false 

對(duì)其他值進(jìn)行空檢查

接著,我們用一些值上測(cè)試我們的方法,看看我們會(huì)得到了什么

function isEmptyObject(value) {
  return Object.keys(value).length === 0 && value.constructor === Object;
}

到目前為止看起來(lái)不錯(cuò),對(duì)于非對(duì)象它返回?false。

isEmptyObject(100)  // false
isEmptyObject(true) // false
isEmptyObject([])   // false

但是要當(dāng)心! 下面這些值會(huì)引發(fā)錯(cuò)誤。

// TypeError: Cannot covert undefined or null to object
isEmptyObject(undefined);
isEmptyObject(null);

改進(jìn)對(duì)nullundefined的空檢查

如果不想讓它拋出TypeError,可以添加額外的檢查

function isEmptyObject(value) {
  return value && Object.keys(value).length === 0 && value.constructor === Object;
}

B.舊版本瀏覽器中的空對(duì)象檢查

如果你需要支持較舊的瀏覽器怎么辦? 大家都知道,當(dāng)說(shuō)舊的瀏覽器時(shí),指的是?IE,我們有2個(gè)選擇,使用原生或利用庫(kù)。

使用 JavaScript 檢查空對(duì)象

原生的 JS 并不那么簡(jiǎn)潔,但判斷用來(lái)空對(duì)象是沒問題的。

function isObjectEmpty(value) {
  return (
    Object.prototype.toString.call(value) === '[object Object]' && JSON.stringify(value) === '{}'
  );
}

對(duì)于對(duì)象,它返回true。

isObjectEmpty({});           // true 
isObjectEmpty(new Object()); // true 

其它類型的構(gòu)造函數(shù)也能正常判斷

isObjectEmpty(new String());   // false 
isObjectEmpty(new Number());   // false 
isObjectEmpty(new Boolean());  // false 
isObjectEmpty(new Array());    // false 
isObjectEmpty(new RegExp());   // false 
isObjectEmpty(new Function()); // false 
isObjectEmpty(new Date());     // false 

傳入?null?和?undefined?也不會(huì)報(bào)?TypeError

isObjectEmpty(null);      // false
isObjectEmpty(undefined); // false

使用外部庫(kù)檢查空對(duì)象

有大量的外部庫(kù)可以用來(lái)檢查空對(duì)象。而且大多數(shù)都對(duì)舊瀏覽器有很好的支持

Lodash 
_.isEmpty({});
// true
Underscore
_.isEmpty({});
// true
jQuery 
jQuery.isEmptyObject({});
// true

原生 VS 庫(kù)

答案是看情況而定!我非常喜歡盡可能地簡(jiǎn)化程序,因?yàn)槲也幌矚g外部庫(kù)的開銷。另外,對(duì)于較小的應(yīng)用程序,我懶得設(shè)置外部庫(kù)。

但如果你的應(yīng)用程序已經(jīng)安裝了一個(gè)外部庫(kù),那么就繼續(xù)使用它。你會(huì)比任何人都更了解你的應(yīng)用程序。所以選擇最適合你情況的方法。

以上就是原生javascript中檢查對(duì)象是否為空示例實(shí)現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于javascript中檢查對(duì)象是否為空的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 一文詳解websocket在vue2中的封裝使用

    一文詳解websocket在vue2中的封裝使用

    這篇文章主要為大家介紹了一文詳解websocket在vue2中的封裝使用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • Vue.js實(shí)現(xiàn)watch屬性的示例詳解

    Vue.js實(shí)現(xiàn)watch屬性的示例詳解

    本文討論了watch函數(shù)是如何利用副作用函數(shù)和options進(jìn)行封裝實(shí)現(xiàn)的,也通過調(diào)度函數(shù)去控制回調(diào)函數(shù)的立即執(zhí)行和執(zhí)行時(shí)機(jī),還可以解決競(jìng)態(tài)問題,感興趣的可以了解一下
    2022-04-04
  • Vue圖片瀏覽組件v-viewer用法分析【支持旋轉(zhuǎn)、縮放、翻轉(zhuǎn)等操作】

    Vue圖片瀏覽組件v-viewer用法分析【支持旋轉(zhuǎn)、縮放、翻轉(zhuǎn)等操作】

    這篇文章主要介紹了Vue圖片瀏覽組件v-viewer用法,結(jié)合實(shí)例形式分析了v-viewer的基本功能與使用方法,包括旋轉(zhuǎn)、縮放、翻轉(zhuǎn)等操作技巧,需要的朋友可以參考下
    2019-11-11
  • vue一步到位的實(shí)現(xiàn)動(dòng)態(tài)路由

    vue一步到位的實(shí)現(xiàn)動(dòng)態(tài)路由

    這篇文章主要介紹了vue一步到位的實(shí)現(xiàn)動(dòng)態(tài)路由,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • vue-dialog的彈出層組件

    vue-dialog的彈出層組件

    這篇文章主要為大家詳細(xì)介紹了vue-dialog的彈出層組件,可以通過npm引用的組件,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • Vue+FormData+axios實(shí)現(xiàn)圖片上傳功能

    Vue+FormData+axios實(shí)現(xiàn)圖片上傳功能

    這篇文章主要為大家學(xué)習(xí)介紹了Vue如何利用FormData和axios實(shí)現(xiàn)圖片上傳功能,本文為大家整理了詳細(xì)步驟,感興趣的小伙伴可以了解一下
    2023-08-08
  • vue 如何使用遞歸組件

    vue 如何使用遞歸組件

    這篇文章主要介紹了vue 如何使用遞歸組件,幫助大家更好的理解和使用vue,完成開發(fā)需求,感興趣的朋友可以了解下
    2020-10-10
  • vue利用openlayers加載天地圖和高德地圖

    vue利用openlayers加載天地圖和高德地圖

    這篇文章主要介紹了?vue利用openlayers加載天地圖和高德地圖,下文章主要由兩部分完成openlayers加載天地圖和加載高德地圖,下面來(lái)看看詳細(xì)內(nèi)容吧,需要的朋友可以參考一下,希望對(duì)大家有所幫助
    2021-11-11
  • Vue數(shù)據(jù)綁定實(shí)例寫法

    Vue數(shù)據(jù)綁定實(shí)例寫法

    在本篇文章里小編給大家整理的是關(guān)于Vue數(shù)據(jù)綁定實(shí)例寫法以及相關(guān)知識(shí)點(diǎn),需要的朋友們學(xué)習(xí)下。
    2019-08-08
  • Vue實(shí)現(xiàn)固定底部組件的示例

    Vue實(shí)現(xiàn)固定底部組件的示例

    本文主要介紹了Vue實(shí)現(xiàn)固定底部組件的示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07

最新評(píng)論