个人总结简单易懂;
Js函数对象可以分为两类:
Object:
包括创建空对象,创建实例对象我们都是用的Object
Object:
var a={};
a._proto==Object.prototype; true;
var b=function(){}
var c=new b()
c._proto==b.prototype; true;
Function:
function n(){};
n._proto==Function.prototype;true;
那么Object本身也是Function的函数;
所以:
Object._proto==Function.prototype; true;
那么function是有prototupe属性的,所以:
function a(){}
A拥有prototype属性
var b= new a();
实例对象b同时拥有。constructor 和 _proto_属性,
A和b的关系是:
a.prototype==b._proto;
b.constructor = a;
而另外一个函数instanceof就是用来这里监测。a和b是否满足这个原型链过程, 所以 b instanceof a,翻译成大白话就是(b的_proto_属性是否是a的prototype)
以上看完基本就可以很好理解原型链相关知识,需要反复研究梳理。
JS原型链深入解析

本文详细解析了JavaScript中函数对象的两大类别:Object与Function,阐述了它们之间的关系及原型链的工作原理。通过实例说明了如何创建对象和函数,以及它们的_proto_和prototype属性如何工作,帮助读者深入理解JavaScript的原型链机制。
967

被折叠的 条评论
为什么被折叠?



