判断一个js对象,是否具有某个属性

检测对象中属性的存在与否可以通过几种方法来判断。

  • 使用in关键字

该方法可以判断对象的自有属性和继承来的属性是否存在。

var o={x:1};
"x" in o;            //true,自有属性存在
"y" in o;            //false
"toString" in o;     //true,是一个继承属性
  • 使用对象的hasOwnProperty()方法

该方法只能判断自有属性是否存在,对于继承属性会返回false。

var o={x:1};
o.hasOwnProperty("x");       //true,自有属性中有x
o.hasOwnProperty("y");       //false,自有属性中不存在y
o.hasOwnProperty("toString"); //false,这是一个继承属性,但不是自有属性

该方法的一般语法:对象.hasOwnProperty(属性值)

但当对象为null时就会报错,所以一般在使用这个方法时,先判断对象是否为空

if(对象!=null){
    对象.hasOwnProperty(属性值)
}
  • 用undefined判断

自有属性和继承属性均可判断。

var o={x:1};
o.x!==undefined;        //true
o.y!==undefined;        //false
o.toString!==undefined  //true

该方法存在一个问题,如果属性的值就是undefined的话,该方法不能返回想要的结果,如下。

var o={x:undefined};
o.x!==undefined;        //false,属性存在,但值是undefined
o.y!==undefined;        //false
o.toString!==undefined  //true
  • 在条件语句中直接判断
var o={};
if(o.x) o.x+=1;  //如果x是undefine,null,false," ",0或NaN,它将保持不变

猜你喜欢

转载自www.cnblogs.com/shenting/p/10423503.html
今日推荐