在JavaScript中,有几种方法可以检查对象上是否存在一个属性。选择哪种方法在很大程度上取决于实际需求,所以需要我们了解每种方法的工作原理。
让我们来看看最常用的几种方法。
1. 用undefined判断
自有属性和继承属性均可判断。
var o={x:1};
o.x!==undefined; //true
o.y!==undefined; //false
o.toString!==undefined //true
2. in 操作符
如果一个属性存在于一个对象或其原型链上,in操作符返回true。
const myObj = {
someProperty: 'someValue',
someUndefinedProp: undefined,
deleted: 'value'
};
delete myObj.deleted;
console.log('someProperty' in myObj); // true
console.log('someUndefinedProp' in myObj); // true
console.log('toString' in myObj); // true (inherited)
console.log('deleted' in myObj); // false
in操作符不会受到假值问题的影响。然而,它也会对原型链上的属性返回true。这可能正是我们想要的,如果我们不需要对原型链上对属性进行判断,可以使用下面这种方法。
3. hasOwnProperty()
hasOwnProperty()
继承自Object.HasOwnProperty()
。和in操作符一样,它检查对象上是否存在一个属性,但不考虑原型链。
const myObj = {
someProperty: 'someValue',
someUndefinedProp: undefined,
deleted: 'value'
};
delete myObj.deleted;
console.log(myObj.hasOwnProperty('someProperty')); // true
console.log(myObj.hasOwnProperty('someUndefinedProp')); // true
console.log(myObj.hasOwnProperty('toString')); // false
console.log(myObj.hasOwnProperty('deleted')); // false
4.在条件语句中直接判断
var o={};
if(o.x) { //如果x是undefine,null,false," ",0或NaN,它将保持不变
o.x+=1;
}
总之
这三种方法都有其适合使用的场景,重要的是需要我们要熟悉它们的区别,这样才能选择最好的一种,以便让我们的代码能够按照期望运行。