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

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

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

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

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

什么是原生 JavaScript

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

A.在較新的瀏覽器中檢查空對象

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

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

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

你可能想知道為什么我們需要對?constructor?進行檢查。 它是為了覆蓋包裝器實例。在JavaScript中,我們有9個內(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)建一個空對象。

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

因此,僅使用Object.keys,當對象為空時,它的確會返回true。 但是,當我們使用其他構(gòu)造函數(shù)創(chuàng)建新的對象實例時會發(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 解決誤報

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

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 

對其他值進行空檢查

接著,我們用一些值上測試我們的方法,看看我們會得到了什么

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

到目前為止看起來不錯,對于非對象它返回?false。

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

但是要當心! 下面這些值會引發(fā)錯誤。

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

改進對nullundefined的空檢查

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

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

B.舊版本瀏覽器中的空對象檢查

如果你需要支持較舊的瀏覽器怎么辦? 大家都知道,當說舊的瀏覽器時,指的是?IE,我們有2個選擇,使用原生或利用庫。

使用 JavaScript 檢查空對象

原生的 JS 并不那么簡潔,但判斷用來空對象是沒問題的。

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

對于對象,它返回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?也不會報?TypeError

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

使用外部庫檢查空對象

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

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

原生 VS 庫

答案是看情況而定!我非常喜歡盡可能地簡化程序,因為我不喜歡外部庫的開銷。另外,對于較小的應(yīng)用程序,我懶得設(shè)置外部庫。

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

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

相關(guān)文章

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

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

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

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

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

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

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

    vue一步到位的實現(xiàn)動態(tài)路由

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

    vue-dialog的彈出層組件

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

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

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

    vue 如何使用遞歸組件

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

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

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

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

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

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

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

最新評論