首页 > 技术文章 > isPrototypeOf,instanceof, hasOwnProperty,in的作用与区别

zimengxiyu 2019-08-07 11:08 原文

isPrototypeOf

作用:检测一个对象是否是另一个对象的原型。或者说一个对象是否被包含在另一个对象的原型链中

function Fn(name){
                this.name=name;
}
var user=Object.create(Fn);//Object.create()方法创建一个新对象,使用现有的对象来提供新创建的对象的__proto__(即原型指向这个对象)。
console.log(Fn.isPrototypeOf(user)) //true
            
var user1=new Fn('app');
console.log(Fn.prototype.isPrototypeOf(user1)) //true

instanceof

作用:检测一个对象是否是另一个对象的实例。

function Fn(name){
                this.name=name;
}
var user1=new Fn('app');        
console.log(user1 instanceof Fn) //true

hasOwnProperty

作用:对象的hasOwnProperty()方法用来检测给定的属性是否是对象的自由属性,如果是继承属性则返回false(可以用来剔除原型链上的属性

 

function Fn(name){
    this.name=name;
}
Fn.prototype.say="hello";
var user1=new Fn('app');
console.log(user1.hasOwnProperty('say')) //false 原型链上的属性不是对象自身的属性返回false
console.log(user1.hasOwnProperty('age')) //true  对象自身的属性返回true

循环打印出对象自身的属性

function Fn(name){
    this.name=name;
}
Fn.prototype.say="hello";
var user1=new Fn('app');
//循环打印出对象自身的属性
for(var i=0 in user1){
    if(user1.hasOwnProperty(i)){
        console.log([i]+":"+user1[i]);//name:app
    }
}

 

in

作用:判断对象的属性是自由属性还是原型链上的属性,如果对象的自由属性或者继承属性中包含这个属性则返回true。

 

function Fn(name){
    this.name=name;
}
Fn.prototype.say="hello";
var user1=new Fn('app');
console.log('name' in user1) //true  对象自身的属性返回true
console.log('say' in user1) //true  对象原型上的属性返回true

 

 

 

推荐阅读