zoukankan      html  css  js  c++  java
  • js三座大山之一:原型和原型链

    在原型链中,Object是顶级公民,function是一级公民,其他的是二级公民,先记住这句话,下面我们来讲解一下为什么这么说。

    1.原型prototype:javascript中所有函数都具有这个属性,所有具有prototype属性的对象都是一个函数。prototype的作用是向对象添加一个方法/属性。

    function persion(){}
    persion.prototype.name = "xiaoming"
    console.log(persion.prototype)//{name: "xiaoming", constructor: ƒ}

    2.原型指针:__proto__

    如果将上面persion函数生成一个实例对象Persion1,用prototype为他添加一个属性写法如下:

    function persion(){}
    persion.prototype.name = "xiaoming"
    let Persion1 = new persion();
    console.log(Persion1) //控制台结果如下

    打印实例Persion1的结果如下:

    从上面打印的结果来看,Persion1.__proto__.name = persion.prototype.name,也就是实例对象的__proto__属性等于其构造函数的prototype。

    理解了上面之后,原型链就很好理解了,我们可以通过Persion1.__proto__.__proto__直接查找到Object的方法。这么说可能不太直观,上代码:

        function persion(){}
        persion.prototype.name = "xiaoming"
        let Persion1 = new persion();
        console.log(Persion1.__proto__.__proto__.toString) //通过原型链查找到的Object的toString方法
        console.log(Object.prototype.toString)//Object上的toString方法

      控制台打印结果如下,这样就印证原型链逐级查找的特性。

     总结:任何对象都可以通过原型链,也就是__proto__属性,逐级查找,最终的重点都是Object,必经之路是function。他们的关系像是用一条链子串起来一样,我们把这种关系叫做原型链

    最后送大家一张图辟邪

     

  • 相关阅读:
    npm 操作
    vue 下拉框选中不显示的问题
    VUE项目中遇到的Bug总结
    Websocket练手
    Mysql 去重取最新的一条数据
    C# 一列数的规则如下:1、1、2、3、5、8、13..…...求第30位数是多少,用递归算法实现
    冒泡排序 升序 降序(笔试)
    Sql语句查询成绩大全(Mysql,sqlserver,oracle)常遇笔试题
    C# ,.net 对比两个List的方法 亲测
    C#当前时间加、减指定时间
  • 原文地址:https://www.cnblogs.com/panda-programmer/p/12993647.html
Copyright © 2011-2022 走看看