js判斷一個對象Object是否為空對象

js判斷空對象的方法
判斷一個js對象是否是空對象isEmptyObject
author: @TiffanysBear

方法一:使用for...in遍歷

var isEmptyObject = function () {
    for (var i in this) {
        return false;
    }
    return true;
}
// 盡量不要使用object.prototype直接進行修改
// 否則會為繼承時生成的對象新增不必要的可枚舉屬性
// 同時可被for-in枚舉到
Object.defineProperty(Object.prototype, 'isEmptyObject', {
    writable: false,
    configurable: false,
    enumerable: false,
    value: isEmptyObject
});

方法二:使用JSON.stringify方法

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

Object.defineProperty(Object.prototype, 'isEmptyObject', {
    writable: false,
    configurable: false,
    enumerable: false,
    value: isEmptyObject
});

方法三:使用ES6的Object.keys

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

Object.defineProperty(Object.prototype, 'isEmptyObject', {
    writable: false,
    configurable: false,
    enumerable: false,
    value: isEmptyObject
});

如果不支持Object.keys,采用如下的polyfill:

if (!Object.keys) {
  Object.keys = (function () {
    var hasOwnProperty = Object.prototype.hasOwnProperty,
        hasDontEnumBug = !({toString: null}).propertyIsEnumerable('toString'),
        dontEnums = [
          'toString',
          'toLocaleString',
          'valueOf',
          'hasOwnProperty',
          'isPrototypeOf',
          'propertyIsEnumerable',
          'constructor'
        ],
        dontEnumsLength = dontEnums.length;

    return function (obj) {
      if (typeof obj !== 'object' && typeof obj !== 'function' || obj === null) {
          throw new TypeError('Object.keys called on non-object');
      }

      var result = [];

      for (var prop in obj) {
        if (hasOwnProperty.call(obj, prop)) result.push(prop);
      }

      if (hasDontEnumBug) {
        for (var i=0; i < dontEnumsLength; i++) {
          if (hasOwnProperty.call(obj, dontEnums[i])) result.push(dontEnums[i]);
        }
      }
      return result;
    }
  })()
};

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 本文為阮一峰大神的《ECMAScript 6 入門》的個人版提純! babel babel負(fù)責(zé)將JS高級語法轉(zhuǎn)義,...
    Devildi已被占用閱讀 2,129評論 0 4
  • 1.屬性的簡潔表示法 允許直接寫入變量和函數(shù) 上面代碼表明,ES6 允許在對象之中,直接寫變量。這時,屬性名為變量...
    雨飛飛雨閱讀 1,261評論 0 3
  • 屬性的簡潔表示法 ES6允許直接寫入變量和函數(shù),作為對象的屬性和方法。 上面代碼表明,ES6允許在對象之中,直接寫...
    oWSQo閱讀 568評論 0 0
  • 首先一個是對JS中Object的理解:JavaScript中函數(shù)是一等公民,寫在代碼中的 Array/Object...
    皮皮坤666閱讀 1,759評論 0 3
  • 函數(shù)和對象 1、函數(shù) 1.1 函數(shù)概述 函數(shù)對于任何一門語言來說都是核心的概念。通過函數(shù)可以封裝任意多條語句,而且...
    道無虛閱讀 4,945評論 0 5

友情鏈接更多精彩內(nèi)容