JS中的hasOwnProperty()和isPrototypeOf()属性实例详解

这两个属性都是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:

rush:js;"> 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()方法对待自身属性和继承属性的区别。

rush:js;"> var o =new Object(); o.prop="exists"; o.hasOwnProperty("prop");//true 自身的属性 o.hasOwnProperty("toString");//false 继承自Object原型上的方法 o.hasOwnProperty("hasOwnProperty");//false 继承自Object原型上的方法

3.修改原型链后hasOwnproperty()的指向例子

下面的列子演示了hasOwnproperty()方法对待修改原型链后继承属性的区别

rush:js;"> 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 会遍历出对象继承中的可枚举属性

rush:js;"> 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()方法会被覆盖掉

rush:js;"> 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()方法测试一个对象是否存在另一个对象的原型链上

语法

rush:js;"> //object1是不是Object2的原型,也就是说Object2是Object1的原型,,否则false object1.isPrototypeOf(Object2);

描述

isPrototypeOf()方法允许你检查一个对像是否存在另一个对象的原型链上

实例

1.利用isPrototypeOf()检查一个对象是否存在另一个对象的原型上

rush:js;"> 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()检查一个对象是否存在一另一个对象的原型链上

rush:js;"> 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()属性实例详解。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...