zoukankan      html  css  js  c++  java
  • JavaScriptconstructor实现原理(转)

    constructor是什么

    简单的理解,constructor指的就是对象的构造函数。请看如下示例:

    ?

    1

    2

    3

    4

    5

    6

    function Foo(){};

    var foo = new Foo();

    alert(foo.constructor);//Foo

    alert(Foo.constructor);//Function

    alert(Object.constructor);//Function

    alert(Function.constructor);//Function

    对于foo.constructorFoo,我想应该很好理解,因为foo的构造函数为Foo。对于FooObjectFunction的构造函数为Function,我想也没什么好争议的。(因为Foo,Object,Function都是函数对象,又因为所有的函数对象都是Function这个函数对象构造出来,所以它们的constructorFunction,详细请参考《js_函数对象》)

     

    PrototypeConstructor的关系

    ?

    1

    2

    function Dog(){}

    alert(Dog === Dog.prototype.constructor);//true

    JavaScript 中,每个函数都有名为“prototype”的属性,用于引用原型对象。此原型对象又有名为“constructor”的属性,它反过来引用函数本身。这是一种循环引用

    constructor属性来自何方

    我们来看一下Function构造String的构造过程:

     

    注:Function构造任何函数对象的过程都是一样的,所以说不管是String,Boolean,Number等内置对象,还是用户自定义对象,其构造过程都和上图一样。这里String只是一个代表而矣!

    图中可以看出constructorFunction在创建函数对象时产生的,也正如'prototypeconstructor的关系'中讲的那样,constructor是函数对象prototype链中的一个属性。即String=== String.prototype.constructor

     

    我还想用一段代码来证明一下,理论是正确的:

    ?

    1

    2

    3

    4

    5

    6

    7

    8

    9

    function Person(){}

    var p = new Person();

    alert(p.constructor);//Person

    alert(Person.prototype.constructor);//Person

    alert(Person.prototype.hasOwnProperty('constructor'));//true

      

    alert(Person.prototype.isPrototypeOf(p));//true

    alert(Object.prototype.isPrototypeOf(p));//true

    alert(Person.prototype == Object.prototype);//false

    到现在,你会发现这和前面《原型链的实现原理》中的默认prototype指向Object.prototype有冲突,显然当时的理论不是很全面。

     

    特别的Object

    用心的读者可能会提出这样一问题,你这一套理论并不能适用于Object。因为以下的代码和你上面的理论是冲突的:

    ?

    1

    2

    alert(Object.prototype.hasOwnProperty('constructor'));//true

    alert(Object.prototype.hasOwnProperty('isPrototypeOf'));//true,如果按上面的理论,这里应该返回false

    真的是这样吗?不是!那我们来看一下特殊的Object是如何处理的:

    你会发现,这图的原理和上面一张图的原理是一样的。这就能正确解释Object.prototype.hasOwnProperty('isPrototypeOf')true!

     

    constructor探究

    ?

    1

    2

    3

    4

    5

    6

    function Animal(){}

      

    function Person(){}

      

    var person = new Person();

    alert(person.constructor); //Person

    根据上一节的内容,你能正确的理解这段代码的结果吗?思考后,看一下其内存表示:

     

    这张图明确有表明了Function构造AnimalPerson的过程。同时也显示了实例personPerson的关系。 

    再深入一点,代码如下:

    ?

    1

    2

    3

    4

    5

    6

    7

    function Animal(){}

    function Person(){}

      

    Person.prototype = new Animal();

      

    var person = new Person();

    alert(person.constructor); //Animal

    这个时候,person的构造函数成了Animal,怎么解

     

    注:图中的虚线表示Person默认的prototype指向(只作参考的作用)。但是我们将Person.prototype指向了new Animal

    此时,Personprototype指向的是Animal的实例,所以personconstructorAnimal这个构造函数。

     

    结论:constructor的原理非常简单,就是在对象的原型链上寻找constructor属性。

     

    :如果你无法正确理解本文内容,请回顾前面章节的内容。

  • 相关阅读:
    HDU 1847
    HDU 1717
    KMP未优化模板、
    Codeforces Round #340 (Div. 2) B. Chocolate
    HDU 1042 N!
    HDU 1018 Big Number
    HDU 1031 Design T-Shirt
    解决Windows 7删除执行过的 EXE、Bat文件有延迟的问题
    修改Android手机的“虚拟机堆大小”和android:largeHeap来防止APP内存溢出问题
    Android引用百度定位API第三方组件后导致其它.so文件无法正常加载的问题
  • 原文地址:https://www.cnblogs.com/syf/p/2709333.html
Copyright © 2011-2022 走看看