JavaScript原型链顶层原理
JS中原型链,说简单也简单。
首先明确: 函数(Function)才有prototype属性,对象(除Object)拥有__proto__。
首先,我画了一张图。
所谓原型链,指的就是图中的proto这一条指针链!
原型链的顶层就是Object.prototype,而这个对象的是没有原型对象的。
可在chrome的控制台里面输入:
Object.__proto__
输出是:
function Empty() {}
- Object.prototype是由上层对象创建的 (一些静态语言,像C++和Java),在这里为了不引起误会将其指向了null
- Object.prototype创造了Function.Prototype
- Function.prototype创造了Function
- Function创造了Object(注意这里的Object的 proto 指向的是Function.prototype,想一想原型链的知识就明白了)
- Object创造了其他对象(window, document, 自定义对象)
注意
- 要理解原型链顶层要和原型链其他地方的理解有一些不同,这里Object和Function及其原型要分开看,不能将原型和本身看作是理所当然的关系
- Object.prototype和Object的关系
Object.prototype是JS世界中最早生成的,理论上有了原型(Object.prototype)就会有本身(Object),然而Object的内容却是由Function构成的~~用通俗一点的话来解释就是,有了Object.prototype就有了Object的肉体,然而Object的灵魂却是由Function构成的
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通