JavaScript原型详情

80 阅读2分钟

如果我们想要搞清楚JavaScript的原型,首先我们需要搞清楚以下几个概念

  1. 函数:函数就是一个js中的代码块,它的定义方式就是function 函数名(){ };
  2. 构造函数:它和普通函数本身并没有什么区别,但我们通过new 来调用时,我们就叫它构造函数,它的首字母一般大写
  3. 对象:js中所用的东西全为对象(数组,函数,字符串...)
  4. 实例对象:通过new来创建的对象,实例对象.
  5. 原型对象:当我们创建一个函数的时候,这个函数就会有一个prototype对象属性,这个对象属性去指向另一个对象,而这个对象我,我们就称他为原型对象.
    function Person() {
       
    };//这里的Person()就是一个普通函数
    var p = new Person(); //而这里的Person()就是一个构造函数
    console.log(Person.prototype); // Object{} 
    console.log(p.prototype); //undefined

这里的p就是一个实例对象(也就是new Person()) 了解清除了这几个概念,我们来深入理解原型对象

首先我们知道了,只要我们创建一个函数,他就会有一个prototype的属性,而这个属性指向原型对象,这这个原型对象中也有一个属性constructor,这个属性指向创建他的原型对象的构造函数.

用图表示:原型图解释

而在我们创建对象的时候,都有一个叫做 proto 的内置属性,用于指向创建它的构造函数的原型对象。 用图表示: 在这里插入图片描述 进行验证:

    function Person() {
       
    }
    var p = new Person()
    console.log(Person.prototype); // Object{} 
    console.log(p.prototype); // undifined
    console.log(p.constructor); //function Person(){}    
    此处的p是通过 Person函数构造出来的,所以p的constructor属性指向Person
    console.log(Person.constructor); //function Function(){}
    console.log(p.__proto__ === Person.prototype) //ture
    console.log(Person.prototype.constructor === Person) //ture
    console.log(Person.prototype.constructor === p) //false

他们之间的关系:

1)构造函数、原型和实例的关系

①函数都有一个属性prototype,这个属性是指向原型对象

②原型对象prototype里面有一个constructor属性,该属性指向原型对象所属的构造函数

③实例对象都有一个_proto_属性,该属性也指向构造函数的原型对象,它是一个非标准属性,不可以用于编程,它是用于浏览器自己使用的

2)prototype与_proto_的关系

①prototype是函数的属性

②_proto_是实例对象的属性
          ——这两者都指向同一个原型对象