真正理解原型、原型链之间的关系

前言:

“一切皆为对象”
        JavaScript是一个面向(原型)对象的语言,对象是属性的集合,除了值类型 ”一切(引用类型)皆为对象“,判断一个变量是不是对象,值类型可以用typeof,引用类型用instanceof。

我们可以通过new来创建一个对象,但其实所有对象都是通过函数创建的,而函数也是对象。等等,这好像有点绕,不急,让我们先去了解prototype原型。

原型

概念:函数都有prototype属性,称之为原型,也称为原型对象。

  • 原型可以放一些属性和方法,共享给实力对象使用
  • 原型可以做继承

 原型链

概念:对象都有__proto__(隐式原型_)属性,这个属性指向它的原型对象,原型对象也是对象,也有__proto__属性,指向原型对象的原型对象,这样一层一层形成的链式结构称为原型链,最顶层找不到则返回null 。

 关系图:

function Person(name,age){
    this.name = name;
    this.age = age;
}
let person = new Person("Nicholas",18);

// 构造函数的实例指向的是构造函数的原型
console.log(person.__proto__ === Person.prototype) // true

// 构造函数可以做一些判断类的,判断是否为某个构造函数的实例
console.log(person instanceof Person) // true

// 是不是和instanceof很类似?但是不能判断更深层次的继承关系,constructor是可以被修改的,不建议使用
console.log(person.constructor === Person) // true
// constructor 指向的也是 Person
console.log(person.__proto__.constructor === Person.prototype.constructor === Person) // true

// 例如:
console.log([].constructor == Array); // true
// function Fn(){}
console.log(Fn.constructor === Function)

 

除了Function,我们还要介绍一下 Object: 

var obj = {};
console.log(obj.__proto__ === Object.prototype);  // true 

 跟函数Person是被Function创建的一样,obj本质上也是由 Object 创建的。


 

优势:节省内存,只有js才有的特性。

常用的继承方式:寄生式继承,寄生组合式继承,原型链继承,class类继承,构造函数继承。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 原型是每个 JavaScript 对象都有的一个内部属性,它指向另一个对象,该对象包含共享属性和方法。原型链是由原型对象组成的链,它允许对象继承另一个对象的属性和方法。当我们访问一个对象的属性或方法时,如果该对象本身没有该属性或方法,JavaScript 引擎会沿着原型链向上查找,直到找到该属性或方法或者到达原型链的顶端。 ### 回答2: 在JavaScript中,每个对象都有一个原型对象,它是用来共享属性和方法的。当我们访问一个对象的属性或方法时,如果对象本身没有这个属性或方法,JavaScript会沿着原型链依次查找,直到找到该属性或方法或者找不到为止。 原型对象是通过构造函数创建的,可以将构造函数的原型属性称为原型对象。当我们使用构造函数创建一个对象时,这个对象会自动继承构造函数的原型对象上的属性和方法。 原型链是由一系列对象的原型对象组成的链状结构。当我们访问一个对象的属性或方法时,JavaScript会先查找对象本身是否有该属性或方法,若没有则会去它的原型对象中查找,若原型对象中仍然没有,则继续查找原型对象的原型对象,直到查找到顶层的Object.prototype对象为止。 当一个函数被定义时,它会自动创建一个原型对象,并且这个原型对象会默认添加一个constructor属性,该属性指向函数本身。在使用构造函数创建对象时,新创建的对象会继承构造函数的原型对象上的所有属性和方法。 通过原型原型链的机制,我们可以实现对象之间的属性和方法的共享,避免重复创建和占用内存。它使得JavaScript的对象可以实现简单的继承,并且可以方便地进行属性和方法的扩展和修改。 总结起来,原型原型链是JavaScript中实现面向对象特性的重要概念。通过原型链的查找机制,我们可以实现属性和方法的继承和共享,使得代码更加简洁和高效。 ### 回答3: 在JavaScript中,每个对象都有一个原型(prototype),原型是一个对象,它包含了对象的属性和方法。原型可以被其他对象所共享,这样它们就可以访问到相同的属性和方法。 当我们访问一个对象的属性或方法时,JavaScript引擎会先查找该对象本身是否拥有这个属性或方法,如果没有找到,则会继续查找该对象的原型,即原型链中的下一个对象,以此类推,直到找到该属性或方法,或者查找到达原型链的末尾。 原型链是由原型组成的,即一个对象的原型是另一个对象,而这个对象又有自己的原型,依此类推,形成了一个链条。可以把原型链看作是一种对象之间的继承关系。 当我们创建一个对象时,它会有一个隐藏的属性`__proto__`,指向该对象的原型。我们可以通过`Object.create()`方法来显式地指定对象的原型。如果我们尝试访问对象的一个属性或方法,而该对象本身没有这个属性或方法,JavaScript引擎会自动去原型链上查找,直到找到或者返回`undefined`。 原型原型链的概念在JavaScript中是非常重要的,它们使得对象可以通过继承的方式共享属性和方法,提高了代码的可复用性和扩展性。同时,原型链也是JavaScript实现对象的继承机制的基础。我们可以通过修改原型链上的对象,来为现有对象增加属性和方法,或者扩展对象的行为。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值