这两个属性都是
Object.prototype
所提供:Object.prototype.hasOwnProperty()
和Object.prototype.isPropertyOf()
先讲解hasOwnProperty()
方法和使用。在讲解isPropertyOf()
方法和使用bash
看懂这些至少要懂原型链测试
hasOwnProperty()方法用来判断某个对象是否含有指定的自身属性ui
obj.hasOwnProperty("属性名");//实例obj是否包含有圆括号中的属性,是则返回true,不然是false复制代码
全部继承了Object.prototype
的对象都会从原型链上继承到hasOwnProperty
方法,这个方法检测一个对象是否包含一个特定的属性,
和in
不一样,这个方法会忽略那些从原型链上继承的属性。this
下面的例子检测了对象 o 是否含有自身属性 prop:spa
var o =new Object();
o.prop="exists";
function change(){
o.newprop=o.prop;
delete o.prop;
}
o.hasOwnProperty("prop")//true
change()//删除o的prop属性
o.hasOwnProperty("prop")//false
//删除后在使用hasOwnProperty()来判断是否存在,返回已不存在了复制代码
下面的列子演示了hasOwnProperty()
方法对待自身属性和继承属性的区别。prototype
var o =new Object();
o.prop="exists";
o.hasOwnProperty("prop");//true 自身的属性
o.hasOwnProperty("toString");//false 继承自Object原型上的方法
o.hasOwnProperty("hasOwnProperty");//false 继承自Object原型上的方法复制代码
下面的列子演示了hasOwnProperty()
方法对待修改原型链后继承属性的区别code
var o={name:'jim'};
function Person(){
this.age=19;
}
Person.prototype=o;//修改Person的原型指向
p.hasOwnProperty("name");//false 没法判断继承的name属性
p.hasOwnProperty("age");//true;复制代码
下面的列子演示了如何在遍历一个对象忽略掉继承属性,而获得自身属性。对象
注意· forin
会遍历出对象继承中的可枚举属性继承
var o={
gender:'男'
}
function Person(){
this.name="张三";
this.age=19;
}
Person.prototype=o;
var p =new Person();
for(var k in p){
if(p.hasOwnProperty(k)){
console.log("自身属性:"+k);// name ,age
}else{
console.log("继承别处的属性:"+k);// gender
}
}复制代码
若是一个对象上拥有本身的hasOwnProperty()
方法,则原型链上的hasOwnProperty()
的方法会被覆盖掉原型链
var o={
gender:'男',
hasOwnProperty:function(){
return false;
}
}
o.hasOwnProperty("gender");//不关写什么都会返回false
//解决方式,利用call方法
({}).hasOwnProperty.call(o,'gender');//true
Object.prototype.hasOwnProperty.call(o,'gender');//true复制代码
isPrototypeOf()
方法测试一个对象是否存在另外一个对象的原型链上
//object1是否是Object2的原型,也就是说Object2是Object1的原型,,是则返回true,不然false
object1.isPrototypeOf(Object2);复制代码
isPrototypeOf()
方法容许你检查一个对像是否存在另外一个对象的原型链上
var o={};
function Person(){};
var p1 =new Person();//继承自原来的原型,可是如今已经没法访问
Person.prototype=o;
var p2 =new Person();//继承自o
console.log(o.isPrototypeOf(p1));//false o是否是p1的原型
console.log(o.isPrototypeof(p2));//true o是否是p2的原型复制代码
var o={};
function Person(){};
var p1 =new Person();//继承自原来的原型,可是如今已经没法访问
Person.prototype=o;
var p2 =new Person();//继承自o
console.log(o.isPrototypeOf(p1));//false o是否是p1的原型
console.log(o.isPrototypeof(p2));//true o是否是p2的原型
console.log(Object.prototype.isPrototypeOf(p1));//true
console.log(Object.prototype.isPrototypeOf(p2));//true复制代码
p1
的原型链结构是p1
=>原来的Person.prototype
=>Object.prototype
=>null
p2
的原型链结构是p2
=>o
=>Object.prototype
=>null
p1
和p2
都拥有Object.prototype
因此他们都在Object.Prototype
的原型链上