前端面试之理解原型/构造函数/实例(JavaScript篇)

图解

概念

构造函数

构造函数:用来初始化新创建的对象的函数是构造函数。

function Foo () {
    ...
}
复制代码

每一个构造函数都有一个原型对象即prototype(指针)指向的对象。 而原型对象也有一个属性constructor(构造器)指向构造函数。

实例对象

通过构造函数的new操作创建的对象是实例对象。可以用一个构造函数,构造多个实例对象。

const f1 = new Foo()
const f2 = new Foo()
复制代码

实例对象也有有一个__proto__(非标准顺序)属性。该属性指向实例对象的原型对象。

原型

构造函数通过 new 操作符来创建一个实例 , 实例又可以通过内部指针 proto 指向原型对象。 proto 连接的这一条原型对象就构成了原型链。

function A () {
}

function B () {

}
function C () {

}

B.prototype = new A()
C.prototype = new B()

const c = new C()

console.log(
  c.__proto__ ===  C.prototype,  //  true
  C.prototype.__proto__ === B.prototype,  // true
  B.prototype.__proto__ === A.prototype,  // true
  A.prototype.__proto__ === Object.prototype, // true
  Object.prototype.__proto__ === null // true
)


复制代码

原型链最顶端就是Object.prototype。 而Object.prototype的原型对象是null。

转载于:https://juejin.im/post/5cbae005f265da03973aab1f

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值