欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

js对象是否为空对象的判断方法

程序员文章站 2022-06-10 21:21:54
...

js对象是否为空对象的判断方法

  1. 将json对象转化为json字符串,再判断该字符串是否为"{}"
var obj = {};
var b = (JSON.stringify(obj) == "{}");
console.log(b, '返回true时,是空对象');//true
  1. 使用for in 循环判断
var obj = {}
var isEmptyFn = function() {
    for(var key in obj) {
        return false;
    }
    return true;
}
console.log(isEmptyFn(), '返回true时,是空对象');//true
  1. 使用es6的Object.keys()方法判断
    Object.keys()返回一个所有元素为字符串的数组,其元素来自于从给定的object上面可直接枚举的属性。可以通过判断返回数组的length来判断此对象是否为空。
// 例如:
var obj1 = {
    name: 'yang',
    sex: 'female',
    age: '18'
}
console.log(Object.keys(obj1));// ["name", "sex", "age"]

Object.keys()判断对象是否为空:

var obj2 = {};
var returnArr = Object.keys(obj2);
console.log(returnArr.length===0, '返回true时,是空对象'); // true
  1. Object.getOwnPropertyNames()方法
    与方法3类似,
    此方法是使用Object对象的getOwnPropertyNames方法,获取到对象中的属性名,存到一个数组中,返回数组对象。也是通过判断数组的length来判断此对象是否为空。
    (此方法不兼容ie8)
// 例如:
var obj1 = {
    a: '1',
    b: '2'
}
console.log(Object.getOwnPropertyNames(obj1)); // ["a", "b"]

Object.getOwnPropertyNames()方法判断对象是否为空:

var obj2 = {};
var retArr = Object.getOwnPropertyNames(obj2);
console.log(retArr.length === 0, "返回true时,是空对象"); // true
  1. jQuery的isEmptyObject()方法
    此方法是jQuery将for in(方法2)进行封装,在使用时需要依赖jQuery的js包
var obj = {}
var b = $.isEmptyObject(obj);
console.log(b, "返回true时,是空对象") // true