• js中的原型和原型链


    JS的原型和原型链算是前端面试题的热门题目了,基本上遇见的概率会很大吧!

            首先,什么是原型?

    每一个javascript对象(除null外)创建的时候,就会与之关联另一个对象,这个对象就是我们所说的原型,每一个对象都会从原型中“继承”属性。

    举个例子:

    1. function Person(age) {
    2. this.age = age
    3. }
    4. Person.prototype.name = 'kavin'
    5. var person1 = new Person()
    6. console.log(person1.name) //kavin

     就是说在通过构造函数创建实例的时候,如果去实例中找寻某个属性值的时候,如果他有的话就会直接输出,如果没有的话,就会去它的原型对象中去找。

    prototype:每个函数都有一个prototype属性,这个属性指向函数的原型对象。

    __proto__:这是每个对象(除null外)都会有的属性,叫做__proto__,这个属性会指向该对象的原型。

    constructor:每个原型都有一个constructor属性,指向该关联的构造函数。

    原型相关的知识考点一般就是围绕这张图,那怎么去验证这张图的正确性呢?

    1. console.log(Person===Person.prototype.constructor) // true
    2. console.log(person.__proto__ == Person.prototype) // true
    3. console.log(person.__proto__.constructor == Person) // true
    4. console.log(person.constructor == Person) // true

    然后什么是原型链呢?

    单的回顾一下构造函数、原型和实例的关系:每个构造函数都有一个原型对象,原型对象都包含一个指向构造函数的指针,而实例都包含一个指向原型对象的内部指针。那么假如我们让原型对象等于另一个类型的实例,结果会怎样?显然,此时的原型对象将包含一个指向另一个原型的指针,相应地,另一个原型中也包含着一个指向另一个构造函数的指针。假如另一个原型又是另一个类型的实例,那么上述关系依然成立。如此层层递进,就构成了实例与原型的链条。

    简单的表达就是:上边说道如果实例没有一个属性,它会去它的原型中去找,但是如果它的原型中也没有这个属性呢,会停止寻找么,不一定,因为它的原型可能也有自己的原型,这个时候他就会去它的原型的原型中去寻找,这个时候会停下么,还是不一定,要看他原型的原型有没有原型,这样就形成了一条原型链。

    直到最后一个找不到原型时返回null

     

     

  • 相关阅读:
    Socks5代理和代理IP
    教师节到了,用Python做了个非常好用的学生点名系统
    DNS大全(114DNS 、阿里DNS、百度DNS 、360 DNS、Google DNS)
    Python中的pass语句
    【每日知识】进制转换:二进制、八进制、十六进制
    mac安装hadoop3.2.4
    实验9(交换综合实验)
    【技术分享】堆叠交换机替换指导
    英语——语法——从句——句型和句子成分——笔记
    DevComponents.DotNetBar2之SuperTabControl使用技巧
  • 原文地址:https://blog.csdn.net/weixin_44029226/article/details/125447592