這兩個屬性都是
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
的原型鏈上