javascript判断对象有没有某个属性

// 定义一个动物类
function Animal (name) {
  // 属性
  this.name = name || 'Animal';
  // 实例方法
  this.sleep = function(){
    console.log(this.name + '正在睡觉!');
  }
}

Animal.prototype.test = function() {
    console.log("test")
};


function Cat(name){
  Animal.call(this);
}
(function(){
  // 创建一个没有实例方法的类
  var Super = function(){};
  Super.prototype = Animal.prototype;
  //将实例作为子类的原型
  Cat.prototype = new Super();
})();

var animal = new Animal();
var cat = new Cat();

console.log("1");
console.log('name' in animal); //-->true
console.log(animal.hasOwnProperty('name')); //-->true

console.log("2");
console.log('name' in cat); //-->true
console.log(cat.hasOwnProperty('name')); //-->true

console.log("3");
console.log('sleep' in animal); //-->true
console.log(animal.hasOwnProperty('sleep')); //-->true

console.log("4");
console.log('sleep' in cat); //-->true
console.log(cat.hasOwnProperty('sleep')); //-->true

console.log("5");
console.log('test' in animal); //-->true
console.log(animal.hasOwnProperty('test')); //-->false

console.log("6");
console.log('test' in cat); //-->true
console.log(cat.hasOwnProperty('test')); //-->false

console.log("7");
console.log('__proto__' in animal); //-->true
console.log(animal.hasOwnProperty('__proto__')); //-->false

console.log("8");
console.log('__proto__' in cat); //-->true
console.log(cat.hasOwnProperty('__proto__')); //-->false


console.log(cat); //-->Cat {name: "Animal", sleep: ƒ}
cat.test(); //-->test

由上面的代码总结得出:

"in"能检测出对象的所有属性

"hasOwnProperty"只能检测出对象显性定义过的属性,不能检测出没有显性定义过的和propertype里的属性

 

当然,我们可以用最直接的

if(cat.test) {
}

也是能做到"in"的功能的。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值