• 原型,构造器和实例对象的关系


    每个构造函数都有一个原型对象,原型对象包含一个指向构造函数的指针,而实例都包含一个指向构造函数原型的对象的内部指针。

    1,每个构造函数都一个原型对象##

    我们创建的每一个函数都有一个 prototype 属性,这个属性是一个指针,指向一个对象。

    例子:

    	// 构造函数
    	var SuperPlane = function(){
    		this.name = "xxx";
    	}
    	SuperPlane.prototype.sayName = function(){
    		console.log( this.name );
    	} 
    

    普通函数也具有这个属性,但是,不对函数进行 new 操作的话,原型对象也就没有任何意义。函数内部的 this 也会指向 window。

    2,原型对象包含一个指向构造函数的指针##

    在默认情况下,所有原型对象都会自动获得一个 constructor 属性。就用刚才那个例子来说:

    SuperPlane.prototype.constructor = SuperPlane
    

    下面配一张图说明

    上图可以看到 SuperPlane 构造函数中 prototype 对象包含着 constructor 属性。

    3,实例包含一个指向构造函数原型对象的内部指针##

    javascript 为对象创建了一个内部属性 [proto] ,这个属性指向了构造函数的原型对象。

    例子:

    var plane2 = new SuperPlane()
    

    这个内部属性,不可以直接访问,但是浏览器调试的时候可以看到,如下图:

    想一下当构造函数的原型属性等于另一个对象的实例的时候?

    总结##

    用一张图来代替想说的话

  • 相关阅读:
    关于mybatis中mapper.xmlSQL语句书写的心得
    笔记
    SpringMVC的小总结
    配置generatorConfig.xml自动生成的代码的sql书写问题
    关于SQL中的排序问题
    鼠标的change事件
    Git学习笔记 --第一章
    XHR对象
    黑马程序员——java学习6(127-151)——多线程
    黑马程序员——java学习5(107-126)——内部类,异常,包
  • 原文地址:https://www.cnblogs.com/zhiyuan-2011/p/4831550.html
Copyright © 2020-2023  润新知