百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

原型与原型链,一个步骤一个张图,通俗易懂

myzbx 2025-08-31 06:15 8 浏览

相信很多的前端对这个概念都不陌生吧。

面试八股文,可以说是必问的一道题,也是很多前端包括之前的我,也是稀里糊涂的,不知所以然。经过我多日的研究,终于肝明白了,废话不多说,直接上图。


现在看到这张图是不是头大,因为网上很多这种图,我刚开始的时候也是走马观花,直接看麻了。主要是需要自己动手体验一下这种过程,你才能明白这图意义何在。

Constructor 构造函数

构造函数应该不陌生吧(构造函数一般为了区别普通函数要求首字母大写),我们先来下一个构造函数

function Person(){}

prototype 原型

什么是原型?原型其实就是一个对象,实例“继承”那个对象的属性,通过“继承”的这种方式,new出来的实例也有了这个属性。(“继承”这个过程是在new内部实现的

先来说一下原型和构造函数的关系,从下图可以看到构造函数内部有一个prototype的属性,通过这个属性就能访问到原型。


let obj = {}
obj.__proto__.haha = 'gogo'
console.log(obj.haha) // "gogo"

实例对象通过_proto_就能访问到原型的属性(等会会讲到实例访问原型)。

也就是Person是构造函数,Person.prototype就是原型,那么由此可见,就得到了下面的关系图。



instance 实例

有了构造函数,我们就可以直接在原型上创建可以“继承”的属性,并通过new来操作它。

由此,我们又得到了下图↓


proto 隐式原型

上面也说了通过_proto_可以直接访问到原型,所以如果是实例,那么就可以直接通过这个属性访问到原型,由此,我们又可以得到下面的关系图。


既然构造函数通过 prototype 来访问到原型,那么原型也应该能够通过某种途径访问到构造函数,于是乎又得到了下图。


原型链

原型同样也可以通过 __proto__ 访问到原型的原型,比方说这里有个构造函数 Person 然后“继承”前者的有一个构造函数 People,然后 new People 得到实例 p

当访问 p 中的一个非自有属性的时候,就会通过 __proto__ 作为桥梁连接起来的一系列原型、原型的原型、原型的原型的原型直到 Object 构造函数为止。

这个搜索的过程形成的链状关系就是原型链

看到 null 了吗,原型链搜索搜到 null 为止,搜不到那访问的这个属性就是不存在的:

以上就是原型与原型链、构造函数、实例之间的联系,其实并不复杂。如果你理解了这一步,你就可以去了解prototype为何会出现?真正的构造函数属性藏在哪里?

相关推荐

半导体行业术语缩写词典总结-JKL_半导体词汇缩写表

作为半导体行业新人来说,最痛苦的莫过于各种缩写词术语了,有的缩写词一样但是会有不同的解释。这里作者给大家整理了部分术语词典,后面会按照更新顺序一一分享出来。废话不多说,直接开始,如有遗漏,欢迎大家在评...

JD.com Deepens Push Into Embodied Intelligence With Investment in Sensor Maker PaXiniTech

ToraOne,thesecond-generationmultidimensionaltactilehumanoidrobotdevelopedbyPaXiniTechTMTPOS...

Hong Kong's Consumer Market Becomes New Battleground for Chinese Mainland Internet Giants

AI-generatedimageTMTPOST--StrollthroughthestreetsofHongKongtoday,anditmightfeellikey...

http2解决了哪些问题_简述http2的优点

HTTP/2(最初称为SPDY)是HTTP协议的第二个主要版本,它在HTTP/1.1的基础上进行了重大改进,旨在解决其在性能和效率方面的诸多瓶颈。以下是HTTP/2主要解决的问题:队头阻...

China's economy stays strong and vital amid pressure

Peoplevisitthe4thChina-CEECExpo&InternationalConsumerGoodsFairinNingbo,eastChina's...

JD.com Makes $2.4 Billion Bid for Ceconomy in Bold Push to Build a Global Retail Empire

TMTPOST--JD.comhasunveiledplanstoacquireGermany’sCeconomyAG—theparentofEurope’sleading...

深入剖析 Java 中的装饰器设计模式:原理、应用与实践

在Java软件开发的广阔天地里,设计模式犹如璀璨星辰,照亮我们构建高效、可维护系统的道路。今天,让我们聚焦于其中一颗闪耀的星——装饰器设计模式,深入探究它的奥秘,看看如何利用它为我们的代码赋予...

组合模式应用-适配器模式_适配器组件

写在前面Hello,我是易元,这篇文章是我学习设计模式时的笔记和心得体会。如果其中有错误,欢迎大家留言指正!该部分为各模式组合使用,涉及代码较多,熟能生巧。内容回顾定义适配器模式是一种结构型设计模式,...

OOM (Out Of Memory) 故障排查指南

1.确认OOM类型首先需要确认是哪种类型的OOM:JavaHeapOOM:Java堆内存不足NativeMemoryOOM:本地内存不足MetaspaceOOM:元空间内存不足Contai...

刷完这49题,面试官当场给Offer!Java程序员必备指南

1.问题:如果main方法被声明为private会怎样?答案:能正常编译,但运行的时候会提示”main方法不是public的”。2.问题:Java里的传引用和传值的区别是什么?答案:传引用是指传递的是...

C#编程基础(看这一篇就够了)_c#编程入门与应用

C#及其开发环境简介C#概述C#是一个现代的、通用的、面向对象的编程语言,由微软(Microsoft)开发,经Ecma和ISO核准认可。它由AndersHejlsberg和他的团队在.NET框架开发...

说一下JDK的监控和 线上处理的一些case

一句话总结JDK监控常用工具包括JConsole、VisualVM、JMC等,用于实时查看内存、线程、GC状态。线上常见问题处理:内存泄漏通过heapdump分析对象引用链;频繁GC可调整-Xmx/...

JavaScript深拷贝极简指南:3种方法解决嵌套与循环引用难题

为什么需要深拷贝?首先我们看看浅拷贝,point指向的是同一个地址,这时我们修改obj2.point的属性时,obj1的point属性也会被修改再看看深拷贝,point指向的是不同地址,这时我们修改o...

Java 25 在 JEP 519 中集成了紧凑对象头

作者|ANMBazlurRahman译者|刘雅梦策划|丁晓昀Java25通过JEP519将紧凑对象头作为产品特性进行了集成,在不需要更改任何代码的情况下,为开发人员提供了...

每日一练 Python 面试题(1)_python每日一记

以下是5道Python基本语法相关的面试题,涵盖变量、运算符、数据结构、函数和异常处理等核心概念:1.变量与作用域题目:以下代码的输出是什么?解释原因。x=10deffunc():...