JavaScript原型详情

JavaScript原型详情

如果我们想要搞清楚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_是实例对象的属性
          ——这两者都指向同一个原型对象
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值