这两个属性都是Object.prototype所提供:Object.prototype.hasOwnProperty()和Object.prototype.isPropertyOf()
先讲解hasOwnProperty()方法和使用。在讲解isPropertyOf()方法和使用
看懂这些至少要懂原型链
一、Object.prototype.hasOwnProperty()
概述
hasOwnProperty()方法用来判断某个对象是否含有指定的自身属性
语法
obj.hasOwnProperty("属性名");//实例obj是否包含有圆括号中的属性,是则返回true,否则是false
描述
所有继承了Object.prototype的对象都会从原型链上继承到hasOwnProperty方法,这个方法检测一个对象是否包含一个特定的属性,和in不同,这个方法会忽略那些从原型链上继承的属性。
实例
1.使用hasOwnProperty()方法判断某对象是否含有特定的自身属性
下面的例子检测了对象 o 是否含有自身属性 prop:
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()来判断是否存在,返回已不存在了
2.自身属性和继承属性的区别
下面的列子演示了hasOwnProperty()方法对待自身属性和继承属性的区别。
var o =new Object(); o.prop="exists"; o.hasOwnProperty("prop");//true 自身的属性 o.hasOwnProperty("toString");//false 继承自Object原型上的方法 o.hasOwnProperty("hasOwnProperty");//false 继承自Object原型上的方法
3.修改原型链后hasOwnProperty()的指向例子
下面的列子演示了hasOwnProperty()方法对待修改原型链后继承属性的区别
var o={name:'jim'}; function Person(){ this.age=19; } Person.prototype=o;//修改Person的原型指向 p.hasOwnProperty("name");//false 无法判断继承的name属性 p.hasOwnProperty("age");//true;
4.使用hasOwnProperty()遍历一个对象自身的属性
下面的列子演示了如何在遍历一个对象忽略掉继承属性,而得到自身属性。
注意· 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 } }
5.hasOwnProperty方法有可能会被覆盖
如果一个对象上拥有自己的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
二、Object.prototype.isPrototypeOf()
概述
isPrototypeOf()方法测试一个对象是否存在另一个对象的原型链上
语法
//object1是不是Object2的原型,也就是说Object2是Object1的原型,,是则返回true,否则false object1.isPrototypeOf(Object2);
描述
isPrototypeOf()方法允许你检查一个对像是否存在另一个对象的原型链上
实例
1.利用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的原型
2.利用isPropertyOf()检查一个对象是否存在一另一个对象的原型链上
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的原型链上
三、总结
1.hasOwnProperty:是用来判断一个对象是否有你给出名称的属性或对象。不过需要注意的是,此方法无法检查该对象的原型链中是否具有该属性,该属性必须是对象本身的一个成员。
2.isPrototypeOf是用来判断要检查其原型链的对象是否存在于指定对象实例中,是则返回true,否则返回false。
以上所述是小编给大家介绍的JS中的hasOwnProperty()和isPrototypeOf()属性实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]