• js中的hasOwnProperty()和isPrototypeOf()


     

    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:

    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
    p1p2都拥有Object.prototype所以他们都在Object.Prototype的原型链上


    三、总结

    1. hasOwnProperty:是用来判断一个对象是否有你给出名称的属性或对象。不过需要注意的是,此方法无法检查该对象的原型链中是否具有该属性,该属性必须是对象本身的一个成员。
    2. isPrototypeOf是用来判断要检查其原型链的对象是否存在于指定对象实例中,是则返回true,否则返回false。
     
  • 相关阅读:
    eclipse 下载 WindowBuilder
    CLOB、BLOB , CLOB与BLOB的区别
    rpm 安装并配置MySQL(包含指定数据存储路径)
    此Flash Player 与您的地区不相容,请重新安装Adobe Flash Player问题解决
    Eclipse 如何添加 更换字体(转载)
    Eclipse安装WebJavaEE插件、Eclipse编写HTML代码(综合问题统一记录)
    关于hp proliant sl210t服务器raid 1阵列配置(HP P420/Smart Array P420阵列卡配置)
    LINUX下EFIBOOTMGR的使用,删除UEFI主板多余启动项和添加启动项
    安装Linux系统时LSI RAID卡的驱动挂载
    IBM x3250m5安装redhat 6.5 加载raid卡驱动
  • 原文地址:https://www.cnblogs.com/libin-1/p/5759093.html
Copyright © 2020-2023  润新知