js原型,原型链

Posted ken丶123

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js原型,原型链相关的知识,希望对你有一定的参考价值。

  之前面试的时候遇到过原型和原型链方面的题目,具体的已经忘了,只记得当时回答的稀里糊涂,今天查了一些资料,把自己所理解的写出来,加深记忆。

 

1,前提

  在js中,对象都有__proto__属性,一般这个是被称为隐式的原型,该隐式原型指向构造该对象的构造函数的原型。

  函数比较特殊,它除了和其他对象一样有__proto__属性,还有自己特有的属性----prototype,这个属性是一个指针,指向一个包含所有实例共享的属性和方法的对象,称之为原型对象。原型对象也有一个constructor属性,该属性指回该函数。

 

2,题目分析

  网上找了一个题目,先分析一下

var F = function () {}
Object.prototype.a = function () {}
Function.prototype.b = function () {}

var f = new F()
// 请问f有方法a  方法b吗

  f的__proto__指向F.prototype,F.prototype.__proto__指向Object.prototype,所以f 可以取到a方法, 由于f的原型链上没经过Function.prototype,所以取不到b方法。

  由于构造函数F是由Function new出来的,所以F.__proto__指向Function.prototype,所以F可以取到b方法。

 

  

  

 


以上是关于js原型,原型链的主要内容,如果未能解决你的问题,请参考以下文章

JS高级---原型指向可以改变和原型链

原型对象原型链--js面向对象

浅谈js原型与原型链

关于js中的原型问题

JS原型与原型链终极讲解

JS原型学习之旅之一图了解原型链关系