JS 原型和原型链

news2025/1/11 13:54:48

原型和原型链

  • 1. 了解原型和原型链
    • 1.1 原型
    • 1.2 原型链
  • 2. 原型
    • 2.1 prototype
    • 2.2 `__proto__` 隐式原型
  • 3. 原型链

1. 了解原型和原型链

1.1 原型

原型: prototype 又称显示原型

1、原型是一个普通对象
2、只有构造函数才具备该属性
3、公有属性可操作

1.2 原型链

原型链:__proto__

1、只有对象(普通对象、函数对象)具备
2、私有的对象属性,不可操作

有了上面的概念之后,我们再来探讨一下什么是原型和原型链。

2. 原型

我们知道在JS中每次创建一个函数,该函数就会自动带有一个prototype属性,该属性指向函数的原型对象。

2.1 prototype

// 生成一个构造函数
function Person() {
  this.name = 'wyc'
}

// 在原型上添加属性
Person.prototype.age = 19

// 实例化对象
let person = new Person()

console.log(person);

在这里插入图片描述

上述例子中,函数的prototype指向了一个对象,而这个对象正是调用构造函数时创建的实例的原型,也就是person1和person2的原型。

让我们用一张图来展示 构造函数 与 原型对象 之间的关系:
在这里插入图片描述

2.2 __proto__ 隐式原型

这是js对象中(null和undefined除外)都会存在的属性,这个属性会指向该对象的原型(注意:__proto__因为浏览器兼容性问题,不一定都可以获取到,应当使用Object.getPrototypeOf函数作为获取对象原型的标准API)。

隐式原型只有对象(普通对象、函数对象)才具备,并且隐式原型是一个私有的对象属性,不可操作。

// 生成一个构造函数
function Person() {
  this.name = 'wyc'
}

// 在原型上添加属性
Person.prototype.age = 19

// 实例化对象
let person = new Person()

console.log(Person.prototype);
console.log(person.__proto__);
console.log(person.__proto__ === Person.prototype);

在这里插入图片描述

通过这个打印结果我们会发现,看着上面这张图,让我们来总结下:

  • 构造函数(Person)通过prototype属性指向实例的原型。
  • person是基于原型Person.prototype创建出的实例,并且可以通过__proto__属性指向其原型。
  • Person.prototype和person.__proto__都指向实例的原型。

看着上面的描述来看这张图片
在这里插入图片描述

3. 原型链

在JavaScript 中,每个对象通过__proto__属性指向它的原型对象,这个原型对象又有自己的原型,直到某个对象的原型为 null 为止,这种一级一级的链结构就称为原型链。

class Person {  // 生成父类
  constructor(name) {
    this.name = name;
  }

  drink() {
    console.log('大家都爱喝可乐');
  }
}

class Teacher extends Person {  // 生成子类  继承 父类的属性和方法
  constructor(name, age) {
    super(name)
    this.age = age;
  }

  teach() {
    console.log('wyc 喜欢 前端工作');
  }
}

let my = new Teacher('wyc', 19)
console.log(my);
my.teach();
my.drink()

看下面这副图,通过打印构造函数中的teach方法,能够打印出结果
在打印父类中的drink方法,也是可以打印出结果
在这里插入图片描述

通过下面这副图来详细的了解下

  1. 大家可以看到首先能够展示的是我们构造函数中的数据
  2. 调用teach方法时找不到,那么会通过自己的隐式原型__proto__访问到原型对象,在原型对象中寻找。(红色部分)
  3. 在调用drink方法时找不到,那么先通过__proto__找到自己的隐式原型,可以看出隐式原型中也是没有drink方法的,那么在通过__proto__向上寻找,找到后打印。
  4. 如果一直找到Object.prototype对象上,还没有打印,那么就说明,整个原型链对象上都没有此方法,那么就打印为null
    在这里插入图片描述

我们也可以通过 哈默 这张图理解下:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1014481.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数据治理-元数据管理-元数据类型

定义 元数据,定义和描述其它数据的数据。 类型 业务元数据、技术元数据和操作元数据。在图书馆或信息科学中,可分为描述元数据、结构元数据、管理元数据。 业务元数据 主要关注数据的内容和条件,另包括与数据治理相关的详细信息。业务元数据…

logback异步appender日志源码详解

背景: 日常打印日志时,使用logback的异步写日志几乎是标准的配置方式,本文从源码上看看异步写日志的整个流程 异步Appender日志 一般日志的配置如下所示 appender(“ASYNC-LOG”, AsyncAppender) { neverBlock true queueSize 10000 } 这…

前端需要知道的计算机网络知识----网络安全,自学网络安全,学习路线图必不可少,【282G】初级网络安全学习资源分享!

网络安全(英语:network security)包含网络设备安全、网络信息安全、网络软件安全。 黑客通过基于网络的入侵来达到窃取敏感信息的目的,也有人以基于网络的攻击见长,被人收买通过网络来攻击商业竞争对手企业&#xff0c…

CH07_封装

封装记录(Encapsulate Record | 162) 曾用名:以数据类代替记录(Replace Record with Data Class) organization {name: "Acme Gooseberries", country: "GB"};class Organization {constructor(…

HTML整站规划与规范

文章目录 命名规则命名命名书写 包含样式规范样式重置样式引入页面结构页面宽度页面高度与背景页面设计 网址图标 命名规则 命名 根据每块元素的主题、功能、页面上的位置命名,便于后期更改与维护。 另外:如果所有样式放在同一文件下,可以给…

计算如何剥出艺术品

背景: 今天给大家介绍一篇中国科学技术大学发表的论文《Computational Peeling Art Design》。论文要解决是:如何把球状三维物体的表面连续展开成一些艺术画面,要求是展开表面要占三维物体表面整个面积,展开表面要和艺术体形状尽可…

[CISCN 2022 初赛]online_crt

文章目录 涉及知识点代码审计解题过程 涉及知识点 CVE-2022-1292漏洞OpenSSLssrf 代码审计 app.py源码 import datetime import json import os import socket import uuid from cryptography import x509 from cryptography.hazmat.backends import default_backend from …

LeetCode(力扣)55. 跳跃游戏Python

LeetCode20. 有效的括号 题目链接代码 题目链接 https://leetcode.cn/problems/jump-game/ 代码 class Solution:def canJump(self, nums: List[int]) -> bool:if len(nums) < 1:return Truecover 0for i in range(len(nums)):if i < cover:cover max(cover, i …

【NVIDIA CUDA】2023 CUDA夏令营编程模型(四)

博主未授权任何人或组织机构转载博主任何原创文章&#xff0c;感谢各位对原创的支持&#xff01; 博主链接 本人就职于国际知名终端厂商&#xff0c;负责modem芯片研发。 在5G早期负责终端数据业务层、核心网相关的开发工作&#xff0c;目前牵头6G算力网络技术标准研究。 博客…

性能测试结果评估与展示

面向性能测试部门 对测试资产进行集中管理以及从项目或系统维度进行汇总展示是两种行之有效的管理手段。这些测试资产包括脚本、缺陷描述、测试记录、测试报告、项目需求等资料,通过对这些资料进行分类,当原有人员缺失的情况下,新接手的测试工程师能快速了解关键信息。 使…

Android RecyclerView BaseSectionQuickAdapter实现分组功能

详情网站&#xff1a;手把手教你使用BaseSectionQuickAdapter实现分组功能&#xff0c;史上最详细Adapter使用教程_basequickadapter 分组_杨阿程的博客-CSDN博客 //加入二个包implementation com.android.support:recyclerview-v7:26.0.0-beta1implementation com.github.Cym…

SAP 选择屏幕动态通过Radio Button 显示与隐藏以及控制是否必输

如何在选择屏幕上进行动态展示屏幕字段&#xff0c;并且进行必输项检查控制 1. 选择屏幕定义 SELECTION-SCREEN BEGIN OF BLOCK b1 WITH FRAME TITLE TEXT-001.SELECTION-SCREEN BEGIN OF LINE.PARAMETERS: p_r1 TYPE c RADIOBUTTON GROUP grp USER-COMMAND uc DEFAULT X. &q…

【推荐】赴日IT课程 做赴日IT我该学什么?

许多想要做赴日IT的朋友问我说&#xff0c;我都该准备什么&#xff0c;或者我该学些什么才能达到可以做赴日程序员的水平呢&#xff1f;今天我就来跟大家聊一下这个问题。要说做准备&#xff0c;你需要有全日制大专及以上的学历才能获得赴日的资格&#xff0c;如果没有我们就先…

【Linux】线程的概念

文章目录 &#x1f4d6; 前言1. 线程的引入1.1 执行流&#xff1a;1.2 线程的创建&#xff1a;1.3 线程的等待&#xff1a; 2. 查看线程2.1 链接线程库&#xff1a;2.2 ps -aL&#xff1a; 3. 页表的认识3.1 二级页表&#xff1a;3.2 页表的实际大小&#xff1a; 4. 再看线程4.…

全面深入理解TCP协议(超详细)

目录 前言 TCP协议格式 确认应答机制(ACK) 理解可靠性 确认应答的机制 16位窗口大小 缓冲区 流量控制 6个标志位 16位紧急指针 ★三次握手&#xff0c;四次挥手 如何理解连接 如何理解三次握手 如何理解四次挥手 TCP可靠性机制 确认应答机制(补充) ​编辑…

70、Spring Data JPA 的 自定义查询(全手动,自己写完整 SQL 语句)

1、方法名关键字查询&#xff08;全自动&#xff0c;既不需要提供sql语句&#xff0c;也不需要提供方法体&#xff09; 2、Query查询&#xff08;半自动&#xff1a;提供 SQL 或 JPQL 查询&#xff09; 3、自定义查询&#xff08;全手动&#xff09; ★ 自定义查询&#xff08…

前端开发中,文本单行或多行溢出使用省略号显示

1.文本单行溢出使用省略号显示 关键代码如下&#xff1a; .box1{width: 200px;height: 30px;line-height: 30px;margin: 0 auto;background-color: rgba(220, 220, 220, 0.751);/* 单行文本超出隐藏 用省略号代替 */white-space: nowrap;overflow: hidden;text-overflow: ellip…

SpringMVC系列(七)之自定义注解

目录 一. Java注解简介 1.1 Java注解分类 1.2 JDK基本注解 Override Deprecated SuppressWarnings 1.3 JDK元注解 从 Java 7 开始&#xff0c;额外添加了 3 个注解: 1.4 自定义注解 如何自定义注解&#xff1f; 二. 自定义注解示例 枚举类&#xff1a; 示例一&…

Echarts 散点图的详细配置过程

文章目录 散点图 简介配置步骤简易示例 散点图 简介 Echarts散点图是一种常用的数据可视化图表类型&#xff0c;用于展示两个或多个维度的数据分布情况。散点图通过在坐标系中绘制数据点的位置来表示数据的关系。 Echarts散点图的特点如下&#xff1a; 二维数据展示&#xff…

JAVA成员变量首字母小写,第二个字母大写报错问题(原因:Lombok与Spring冲突)

1、问题现象&#xff1a; JAVA类里定义成员变量使用首字母小写&#xff0c;第二个字母大写 Getter Setter public class BrandQueryObject extends QueryObject{private String pName; }结果页面报错&#xff0c;无法找到类型为 cn.wolfcode.ssm.query.BrandQueryObject 的对象…