原型与原型链
什么是原型(对象)
在JavaScript中,每个对象都具有一个原型对象prototype,目的是:利用原型对象实现在同一原型链中的原型方法共享
在理解原型对象前,需要先了解什么是构造函数
构造函数
用来初始化对象的特殊函数,通过new 对象名(参数)来创建对象实例
构造函数实例化过程:
1. 通过new创建一个空的对象{}
2. 构造函数的this指向改对象
3. 指向构造函数,向该对象赋值
4. 返回新对象
//构造方法
function Parent(name, age) {this.name = name;this.age = age;this.fn = function () { }
}//创建实例
const parent = new Parent('张三', 18);
原型
- 每一个构造函数都有一个prototype属性,该属性指向该函数的原型对象
- 原型对象中的属性对其构造函数实例化的对象共享
- 可以将共用的方法写在prototype中,保证对象实例不会多次创建函数,节省内存
- 构造函数和原型对象中的this都指向实例对象
//构造方法
function Parent(name, age) {this.name = name;this.age = age;this.fn = function () { }
}
Parent.prototype.fn2 = function () { }
//创建实例
const p1 = new Parent('张三', 18);
const p2 = new Parent('李四', 19)
console.log(p1.fn2 === p2.fn2) // true
constructor属性
在每个prototype属性中,都有一个constructor属性,它指向该原型的构造函数

作用:
方便在给原型对象一次性进行多次赋值时,将原型指回其构造函数

对象原型__proto__
- 每个实例对象中都有一个__proto__属性,该属性指向其实例的原型对象
- 正是因为有__proto__的存在,才能使得实例对象可以访问构造函数原型对象中的方法

总结:
- 构造函数通过prototype指向它的原型对象
- 原型对象通过constructor指向它的构造函数
- 通过构造函数实例化的对象中的__proto__属性,指向其构造函数的原型对象

原型继承
根据原型的特性,可以实现对象之间的继承

上述代码,Woman构造函数公共prototype继承了Person对象,使得所有由Woman实例化出来的对象,都可以使用Person对象中的属性。
通过prototype 接收 new Person实例,保证所有子类不会影响父类中的结构
而在Woman构造函数中,可以编写Woman私有的属性
弊端,若父类中定义了引用数据类型,被子类实例的对象所修改,由于他们共同引用同一地址,其他子类也会受到影响

构造函数继承
想要解决上述问题,可以通过在子类创建实例时去执行父类构造函数,并修改this指向为子类实例

组合式继承
结合原型链继承和构造函数继承,弥补了两者的缺点

原型链查找
每个原型对象proptotype中也有一个__proto__属性,它指向其上一级的原型对象
通过这一属性,可以得到一条原型链的查找规则
- 每当需要访问一个对象中是否存在一个属性时
- 先去该实例对象中的私有属性中进行查找
- 若没查到,通过实例对象中的__proto__属性去实例对象的原型prototype中进行查找
- 若还没查到,则根据prototype属性去它的上一级原型中进行查找
- 直到查到Object的原型对象中
- 最终Object的prototype的__proto__属性指向null

利用instanceof方法可以查找某实例对象的原型是否在某个原型链中
Class
class作为es6中原型的语法糖,极大的简化了原型以及原型继承的写法

相关文章:
原型与原型链
什么是原型(对象) 在JavaScript中,每个对象都具有一个原型对象prototype,目的是:利用原型对象实现在同一原型链中的原型方法共享 在理解原型对象前,需要先了解什么是构造函数 构造函数 用来初始化对象的…...
【Linux】信号处理
一、Linux系统信号 1、常见的系统信号 常见的Linux系统信号 信号值描述1SIGHUP挂起(hang up)进程2SIGINT中断进(interrupt)程3SIGQUIT停止(stop)进程9SIGKILL无条件终止(terminate)…...
5个不同类型的mysql数据库安装
各种社区版本下载官方地址:MySQL :: MySQL Community Downloads 一、在线YUM仓库(Linux) 选择 MySQL Yum Repository 选择对应版本下载仓库安装包(No thanks, just start my download.) 下载方法1:下载到本…...
python学习笔记—12—布尔类型、if语句
1. 布尔类型 (1) 定义 (2) 比较运算符 (3) 代码演示 1. 手动定义 bool_1 True bool_2 False print(f"bool_1的内容是:{bool_1}, 类型是:{type(bool_1)}") print(f"bool_2的内容是:{bool_2}, 类型是:{type(bool…...
分数阶傅里叶变换代码 MATLAB实现
function Faf myfrft(f, a) %分数阶傅里叶变换函数 %输入参数: %f:原始信号 %a:阶数 %输出结果: %原始信号的a阶傅里叶变换N length(f);%总采样点数 shft rem((0:N-1)fix(N/2),N)1;%此项等同于fftshift(1:N),起到翻…...
《数据结构》期末考试测试题【中】
《数据结构》期末考试测试题【中】 21.循环队列队空的判断条件为?22. 单链表的存储密度比1?23.单链表的那些操作的效率受链表长度的影响?24.顺序表中某元素的地址为?25.m叉树第K层的结点数为?26. 在双向循环链表某节点…...
openwrt 清缓存命令行
一、查看缓存 : free -m 二、清缓存:echo 3 > /proc/sys/vm/drop_caches 三、详解。 释放物理页缓存 echo 1 > /proc/sys/vm/drop_caches 释放可回收的slab对象,包含inode and dentry echo 2 > /proc/sys/vm/drop_caches 同时…...
RP2K:一个面向细粒度图像的大规模零售商品数据集
这是一种用于细粒度图像分类的新的大规模零售产品数据集。与以往专注于相对较少产品的数据集不同,我们收集了2000多种不同零售产品的35万张图像,这些图像直接在真实的零售商店的货架上拍摄。我们的数据集旨在推进零售对象识别的研究,该研究具…...
.NET Core FluentAPI
目录 约定配置 主要规则 两种配置方式 Data Annotation Fluent API Fluent API配置 Fluent API众多方法 选择 约定配置 主要规则 表名采用DbContext中的对应的DbSet的属性名。数据表列的名字采用实体类属性的名字,列的数据类型采用和实体类属性类型最兼容…...
【C++数据结构——查找】顺序查找(头歌实践教学平台习题)【合集】
目录😋 任务描述 相关知识 一、根据输入数据建立顺序表 二、顺序表的输出 三、顺序查找算法 测试说明 通关代码 测试结果 任务描述 本关任务:实现顺序查找的算法 相关知识 为了完成本关任务,你需要掌握: 根据输入数据建立…...
HTTP Scheme 通常指的是在 URL 中用于指定使用 HTTP 协议的方案(scheme)
HTTP Scheme 通常指的是在 URL 中用于指定使用 HTTP 协议的方案(scheme)。URL(统一资源定位符)中的 scheme 部分指明了访问资源所使用的协议。对于 HTTP,有两个主要的 scheme: - **http**:表示…...
基于Matlab的变压器仿真模型建模方法(13):单相升压自耦变压器的等效电路和仿真模型
1.单相升压自耦变压器的基本方程和等效电路 单相升压自耦变压器的接线原理图如图1所示。在建立自耦变压器的基本方程时,仍然把它看成是从双绕组变压器演变而来。在图1中,设节点a到节点b部分的绕组的匝数为,对应于双绕组变压器的原边绕组;节点c到节点a部分的绕组的绕组匝数为…...
【Vue.js】监听器功能(EventListener)的实际应用【合集】
目录 🤔在实际开发过程中,我遇到了一个颇为棘手的小问题 😋解决这个小问题 问题出现的原因剖析 解决方法阐述 问题成功解决! 📖相关知识总结 基本概念 使用方法 实际应用场景 🤔在实际开发过程中…...
【Shell脚本】Docker构建Java项目,并自动停止原镜像容器,发布新版本
本文简述 经常使用docker部署SpringBoot 项目,因为自己的服务器小且项目简单,因此没有使用自动化部署。每次将jar包传到服务器后,需要手动构建,然后停止原有容器,并使用新的镜像启动,介于AI时代越来越懒的…...
【iOS Swift Moya 最新请求网络框架封装通用】
【iOS Swift Moya 最新请求网络框架封装通用】 前言框架结构1.API定义(TargetType)2. 配置MoyaProvider3. 网络管理器4. 使用示例注意事项进一步优化 前言 设计一个基于Moya的网络请求框架,可以提供灵活的网络请求管理,例如设置请…...
前端批量下载文件
背景 文件管理页面,后端只提供了一个根据 file_path 和 file_name 参数下载文件的API接口。产品需要支持用户多选之后的批量下载功能。 技术实现 基础代码 先调用下载接口,获取到二进制的文件流,然后通过 a 标签完成下载。 // return [r…...
【pytorch-lightning】架构一览
pytorch-lightning是基于pytorch的一个套壳项目,适配pytorch的版本同步更新速度很快。 它将训练的几个主要流程模块化,减少重复工作,同时让支持分布式训练,不同平台的训练迁移变得更加简单。 官网链接...
MongoDB相关使用问题
1.【报错】sort operation used more than the maximum 33554432 bytes of RAM. Add an index MongoDB 排序超过内存限制,限制最大为100M。 解决方式:将内存排序改为磁盘排序 正常用法:数据量大了再排序会报错 Autowired protected MongoO…...
DevSecOps自动化在安全关键型软件开发中的实践、Helix QAC Klocwork等SAST工具应用
DevSecOps自动化对于安全关键型软件开发至关重要。 那么,什么是DevSecOps自动化?具有哪些优势?为何助力安全关键型软件开发?让我们一起来深入了解~ 什么是DevSecOps自动化? DevSecOps自动化是指在软件开发生命周期的各…...
常见的显示器分辨率及其对应的像素数量
显示器的像素数量通常由其分辨率决定,分辨率表示为水平像素数乘以垂直像素数。 720P(1280720): 像素数量:约92.16万特点:这是高清标准的一个分辨率,通常用于手机、平板电脑或小型显示器。900P&…...
GPU加速MediaPipe TouchDesigner插件终极指南:从零构建实时视觉交互
GPU加速MediaPipe TouchDesigner插件终极指南:从零构建实时视觉交互 【免费下载链接】mediapipe-touchdesigner GPU Accelerated MediaPipe Plugin for TouchDesigner 项目地址: https://gitcode.com/gh_mirrors/me/mediapipe-touchdesigner MediaPipe Touch…...
AI 推理精细化流量治理实战:RocketMQ LiteTopic 的“千人千面”流控方案
在技术领域,我们常常被那些闪耀的、可见的成果所吸引。今天,这个焦点无疑是大语言模型技术。它们的流畅对话、惊人的创造力,让我们得以一窥未来的轮廓。然而,作为在企业一线构建、部署和维护复杂系统的实践者,我们深知…...
Python 协程任务池性能优化方案
Python协程任务池性能优化方案 在现代高并发编程中,Python的协程(Coroutine)凭借轻量级线程和高效IO操作成为提升性能的重要工具。当任务数量激增时,简单的协程调度可能导致资源竞争或性能瓶颈。如何优化协程任务池,使…...
Qwen2-VL-2B-Instruct与Transformer架构详解:从原理到微调实践
Qwen2-VL-2B-Instruct与Transformer架构详解:从原理到微调实践 1. 引言:从“看图说话”到“理解世界” 你有没有想过,让AI模型看懂一张图片,并且能跟你聊上几句,这背后到底是怎么实现的?比如你给它一张小…...
面试官: 高并发系统概念解析(答案深度解析)持续更新
什么是高并发系统?——面试官想听的深度答案⚠️ 注意:“能扛住很多请求”不是高并发系统的定义,而是结果;面试官真正想考察的是你对“高并发本质”的理解、设计思维和落地经验。一、概念解释:别被字面意思带偏&#x…...
Visio图表高效转EPS:完整步骤与常见问题解析
1. Visio转EPS的必备工具与前期准备 第一次把Visio图表转成EPS格式时,我对着论文投稿系统里的格式要求发愁了半天。作为科研狗必备技能,这个转换其实比你想象的简单得多。先说说需要准备的软件组合:Visio本身(2013及以上版本更稳…...
OpenClaw Windows 一键部署教程|Win10/11 通用小白版
适配系统:Windows10/11 64 位当前版本:v2.3.10/v2.3.12(虾壳云版)核心优势:全程可视化操作,无需命令行、无需手动配置 Python/Node.js,内置全部运行依赖,5 分钟即可完成部署…...
STM32F103 HAL库实战:DMA+USART驱动RS-485半双工通讯
1. RS-485通讯基础与STM32方案选型 在工业自动化领域,RS-485总线因其抗干扰能力强、传输距离远(最长1200米)、支持多点连接(最多32个节点)等特性,成为传感器网络、PLC控制等场景的首选。与常见的UART不同&a…...
像素史诗·智识终端Anaconda数据科学环境快速搭建与模型管理
像素史诗智识终端Anaconda数据科学环境快速搭建与模型管理 1. 前言:为什么选择Anaconda 在数据科学和AI研究领域,环境管理一直是个让人头疼的问题。不同项目需要的Python版本、库版本经常冲突,手动管理依赖就像在玩俄罗斯方块——迟早会崩溃…...
【AI Agent实战】OpenClaw Skill 技能系统详解:从 Function Calling 到 MCP 到 Skill 的完整演进
关键词:OpenClaw Skill、AI Agent技能、MCP协议、Function Calling、AI工作流一、为什么装完 OpenClaw 还是感觉"没用" 安装完 OpenClaw 之后,很多人反馈一个共同问题:跟直接用 ChatGPT 感觉差不多,没看到明显差异。 原…...
