判断JavaScript对象为null或者属性为空

本文详细解析了JavaScript中null与undefined的区别,包括它们的类型判定和使用场景。并通过具体示例介绍了如何检测一个对象是否为空,探讨了不同方法的优劣。最后,提供了几种实用的代码片段来帮助读者更好地理解和应用这些概念。

首先说下null与undefined区别:

对已声明但未初始化的和未声明的变量执行typeof,都返回"undefined"。

null表示一个空对象指针,typeof操作会返回"object"。

一般不显式的把变量的值设置为undefined,但null相反,对于将要保存对象的变量,应明确的让该变量保存null值。

var bj;
alert(bj);  //"undefined"
bj = null;
alert(typeof bj);  //"object"
alert(bj == null);  //true
bj = {};
alert(bj == null);  //false
/*
 * 检测对象是否是空对象(不包含任何可读属性)。
 * 方法既检测对象本身的属性,也检测从原型继承的属性(因此没有使用hasOwnProperty)。
 */
function isEmpty(obj)
{
    for (var name in obj) 
    {
        return false;
    }
    return true;
};

这里所说的空对象,到底是 {}还是 null .我写了一个测试用例。

var a = {};

a.name = 'realwall';

console.log(isEmpty(a));  //false

console.log(isEmpty({}));  //true

console.log(isEmpty(null));  //true

//注意参数为null时无语法错误哦,即虽然不能对null空指针对象添加属性,但可以使用for in语句。

/*
 * 检测对象是否是空对象(不包含任何可读属性)。
 * 方法只既检测对象本身的属性,不检测从原型继承的属性。
 */
function isOwnEmpty(obj)
{
    for(var name in obj)
    {
        if(obj.hasOwnProperty(name))
        {
            return false;
        }
    }
    return true;
};

{}null的区别:

这个东西很重要。

var a = {};

var b = null;

a.name = 'realwall';

b.name = 'jim'; //这里会报错,b为空指针对象,不能像普通对象一样直接添加属性。

b = a;

b.name = 'jim'; //此时 a和 b指向同一个对象。a.name, b.name均为'jam'

 

做项目时遇到一个问题,判断一个对象是否为空对象,发现这样判断可以,上代码:

1. 代码1:

var a = {};
if(!a){ console.log(1);}
else if(a == null) { console.log(2);} 
else { console.log(3);}

结果为:3

2. 代码2:

var b = {};
if(b == {}){ console.log(4);}
if(b == '{}') { console.log(5);} 
if(typeof(b) == 'object') { console.log(6);}

结果为:6

3. 代码3:

var c = {};
if(JSON.stringify(c) == "{}"){ console.log(7);}

结果为: 7

所以可以使用代码3的方法判断对象是否为空对象{};

如果对象不为空,并且知道对象不为空时,某个属性(比如{id:111})一定存在,则可以里这样判断:

4. 代码4:

var d = {};
var e = {id:111};
if(d.id){ console.log(8);}
if(e.id){ console.log(9);}

结果为:9

小结:显然代码3的判断方式比较“强势”,但效率明显不如代码4的判断方法

补充:

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

 

### 判断 Vue 属性是否为或为 `null` 在 Vue.js 应用程序中,可以通过多种方式来检查一个属性是否为或是 `null`。一种常见的方式是在计算属性(computed properties) 或者方法(methods) 中实现逻辑判断。 #### 使用 JavaScript 原生方法 JavaScript 提供了一些内置函数可以帮助完成这项工作: - **Boolean() 函数**:可以用来检测任何类型的变量是否为假值(例如 `false`, `0`, `-0`, `""`, `null`, `undefined`, 和 `NaN`)。这适用于简单的场景[^1]。 ```javascript if (!this.myProperty) { console.log('myProperty is either null, undefined, an empty string, etc.'); } ``` - **严格相等运算符 (`===`) 和 非严格相等运算符 (`==`)** - 当需要区分不同的假值时,应该使用严格相等运算符(`===`)来进行比较,因为这样不会发生类型转换。 ```javascript // 检查 myProperty 是否确切等于 null if (this.myProperty === null) { ... } // 检查 myProperty 是否是一个字符串 "" if (this.myProperty === '') { ... } ``` 对于更复杂的验证需求,比如确认对象是不是对象,可以根据特定情况进行处理: ```javascript function isEmpty(obj) { return Object.keys(obj).length === 0 && obj.constructor === Object; } // 在 Vue 组件内调用此功能 computed: { isValidData() { return !isEmpty(this.someObject); } } ``` 上述代码片段展示了如何创建一个辅助函数 `isEmpty()` 来确定给定的对象是否有键/值对存在。 另外,在模板语法里也可以直接利用三元表达式或者其他件语句来做类似的判断[^2]: ```html <div v-if="item !== null && item.length">Item has content</div> <!-- 或 --> <span>{{ item ? 'Has Value' : 'No Value' }}</span> ``` 这些技巧能够帮助开发者有效地管理应用程序中的状态并响应变化的数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yusirxiaer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值