JavaScript 中的原型链与继承

news2025/4/4 20:45:32

JavaScript 是一种基于原型的编程语言,这意味着它的对象继承是通过原型链而非类的机制来实现的。原型链是 JavaScript 中对象与对象之间继承属性和方法的基础。本文将深入探讨 JavaScript 中的原型链和继承机制,帮助你理解这一重要概念。

一、原型(Prototype)的概念

在 JavaScript 中,每个对象都有一个内置属性 [[Prototype]],通常我们通过 __proto__ 或者 Object.getPrototypeOf() 来访问它。这个原型对象本身也是一个对象,并且它也有自己的原型。通过这种方式,JavaScript 实现了对象之间的继承。

每个 JavaScript 对象都直接继承自一个原型对象,而这个原型对象又可以有自己的原型。这种层级关系被称为 原型链

二、原型链的工作原理

原型链的工作原理可以通过以下步骤来理解:

  1. 对象的原型:每个对象都可以通过 Object.getPrototypeOf(obj) 或者 obj.__proto__ 来访问其原型。
  2. 查找属性和方法:当我们访问对象的属性或方法时,JavaScript 引擎会首先检查该对象是否有该属性。如果对象自身没有该属性,它会查找对象的原型,如果原型没有,它会继续查找原型的原型,这一过程会一直向上查找,直到找到该属性或者到达原型链的顶端(null)。
    let animal = {
        species: "Dog",
        speak: function() {
            console.log(this.species + " barks!");
        }
    };
    
    let dog = Object.create(animal);
    dog.species = "Beagle";
    
    dog.speak();  // 输出 "Beagle barks!"

    在上面的代码中,dog 对象没有 speak 方法和 species 属性,但它通过原型链继承了 animal 对象的 speak 方法和 species 属性。当我们访问 dog.speak() 时,JavaScript 引擎首先在 dog 对象本身查找,没找到就到 animal 对象上去找。

三、构造函数与原型链

JavaScript 中的对象通常是通过构造函数来创建的,而构造函数本身也是一个函数对象,每个构造函数都有一个 prototype 属性,这个属性指向构造函数的原型对象。

当通过构造函数创建一个实例时,这个实例会自动继承构造函数原型上的属性和方法。让我们来看一个例子:

function Animal(name) {
    this.name = name;
}

Animal.prototype.speak = function() {
    console.log(this.name + ' makes a noise');
};

let dog = new Animal('Buddy');
dog.speak();  // 输出 "Buddy makes a noise"

在这段代码中,Animal 是一个构造函数,我们通过 new Animal() 创建了一个 dog 实例。dog 实例的原型指向 Animal.prototype,因此它能够访问 Animal.prototype 上的 speak 方法。

四、继承的实现

在 JavaScript 中,继承并不像其他面向对象编程语言那样通过类的继承来实现,而是通过原型链来实现的。JavaScript 提供了多种方式来实现继承,常见的有以下几种:

1. 通过构造函数实现继承

通过调用父类构造函数和修改子类的原型,可以实现继承。

function Animal(name) {
    this.name = name;
}

Animal.prototype.speak = function() {
    console.log(this.name + ' makes a noise');
};

function Dog(name) {
    Animal.call(this, name);  // 继承父类的属性
}

Dog.prototype = Object.create(Animal.prototype);  // 继承父类的方法
Dog.prototype.constructor = Dog;  // 修正构造函数指向

let dog = new Dog('Buddy');
dog.speak();  // 输出 "Buddy makes a noise"

在上面的代码中,我们使用 Animal.call(this, name) 来调用父类的构造函数,从而继承了父类的属性。然后,我们将 Dog.prototype 设置为 Object.create(Animal.prototype),这样 Dog 就继承了 Animal 的方法。

2. 通过 ES6 的 class 语法实现继承

ES6 引入了类的语法,使得继承更加直观和易于使用。通过 extends 关键字,我们可以更轻松地实现继承

class Animal {
    constructor(name) {
        this.name = name;
    }

    speak() {
        console.log(this.name + ' makes a noise');
    }
}

class Dog extends Animal {
    constructor(name) {
        super(name);  // 调用父类构造函数
    }
}

let dog = new Dog('Buddy');
dog.speak();  // 输出 "Buddy makes a noise"

在 ES6 的 class 语法中,我们使用 extends 来继承父类,并通过 super() 来调用父类的构造函数。ES6 的 class 语法实际上是对传统 JavaScript 原型链继承的一种封装。

五、总结

JavaScript 中的继承和原型链是相互依存的。每个对象都通过原型链来继承另一个对象的属性和方法,而这一机制使得 JavaScript 的面向对象编程具有非常大的灵活性。虽然 JavaScript 没有传统的类和继承机制,但通过原型链,我们依然可以实现强大的继承和多态机制。

原型链提供了对象之间共享和复用代码的能力,使得我们能够构建更加高效和模块化的代码。理解原型链和继承的工作原理,是深入掌握 JavaScript 的关键之一。

希望这篇博客对你有所帮助!如果有任何问题或建议,欢迎留言讨论

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

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

相关文章

SpringBean模块(一)定义如何创建生命周期

一、介绍 1、简介 在 Spring 框架中,Bean 是指由 Spring 容器 管理的 Java 对象。Spring 负责创建、配置和管理这些对象,并在应用程序运行时对它们进行依赖注入(Dependency Injection,DI)。 通俗地讲,Sp…

Redis-04.Redis常用命令-字符串常用命令

一.字符串操作命令 set name jack 点击左侧name,显示出值。 get name get abc:null setex key seconds value:设置过期时间,过期后该键值对将会被删除。 然后再get,在过期时间内可以get到,过期get不到。…

Epub转PDF软件Calibre电子书管理软件

Epub转PDF软件:Calibre电子书管理软件 https://download.csdn.net/download/hu5566798/90549599 一款好用的电子书管理软件,可快速导入电脑里的电子书并进行管理,支持多种格式,阅读起来非常方便。同时也有电子书格式转换功能。 …

FAST-LIVO2 Fast, Direct LiDAR-Inertial-Visual Odometry论文阅读

FAST-LIVO2 Fast, Direct LiDAR-Inertial-Visual Odometry论文阅读 论文下载论文翻译FAST-LIVO2: 快速、直接的LiDAR-惯性-视觉里程计摘要I 引言II 相关工作_直接方法__LiDAR-视觉(-惯性)SLAM_ III 系统概述IV 具有顺序状态更新的误差状态迭代卡尔曼滤波…

【Git】--- Git远程操作 标签管理

Welcome to 9ilks Code World (๑•́ ₃ •̀๑) 个人主页: 9ilk (๑•́ ₃ •̀๑) 文章专栏: Git 前面我们学习的操作都是在本地仓库进行了,如果团队内多人协作都在本地仓库操作是不行的,此时需要新的解决方案 --- 远程仓库。…

论文阅读笔记——ST-4DGS,WideRange4D

ST-4DGS ST-4DGS 论文 在 4DGS 中,变形场 F \mathcal{F} F 与运动参数 X 和形状参数 ( S , R ) (S,R) (S,R) 高度耦合,导致训练时高斯表示紧凑型退化,影响动态渲染质量。由此,本文提出两种方法解耦运动与形状参数,保…

[python]基于yolov8实现热力图可视化支持图像视频和摄像头检测

YOLOv8 Grad-CAM 可视化工具 本工具基于YOLOv8模型,结合Grad-CAM技术实现目标检测的可视化分析,支持图像、视频和实时摄像头处理。 功能特性 支持多种Grad-CAM方法实时摄像头处理视频文件处理图像文件处理调用简单 环境要求 Python 3.8需要电脑带有…

豪越科技消防一体化平台:打通消防管理“任督二脉”

在城市的车水马龙间,火灾隐患如潜藏的暗礁,威胁着人们的生命财产安全。传统消防管理模式在现代社会的复杂环境下,逐渐显露出诸多弊端。内部管理分散混乱,人员、装备、物资管理缺乏统一标准和高效流程;外部监管困难重重…

【Matlab】-- 基于MATLAB的美赛常用多种算法

文章目录 文章目录 01 内容概要02 各种算法基本原理03 部分代码04 代码下载 01 内容概要 本资料集合了多种数学建模和优化算法的常用代码资源,旨在为参与美国大学生数学建模竞赛(MCM/ICM,简称美赛)的参赛者提供实用的编程工具和…

机器学习课程

前言 课程代码和数据文件: 一、机器学习概述 1.1.人工智能概述 机器学习和人工智能,深度学习的关系 机器学习是人工智能的一个实现途径深度学习是机器学习的一个方法发展而来 达特茅斯会议-人工智能的起点 1956年8月,在美国汉诺斯小镇宁静…

AIGC(生成式AI)试用 28 -- 跟着清华教程学习 - AIGC发展研究 3.0

目标:继续学习 - 信息不对称、不平等、隐私泄露和数据滥用 - 问、改、创、优 - “概率预测(快速反应)”模型和“链式推理(慢速思考)”模型 - 思维滞环现象解决思路:1.调整提问:改变问题方式&…

问题:md文档转换word,html,图片,excel,csv

文章目录 问题:md文档转换word,html,图片,excel,csv,ppt**主要职责****技能要求****发展方向****学习建议****薪资水平** 方案一:AI Markdown内容转换工具打开网站md文档转换wordmd文档转换pdfm…

【Java】面向对象之static

用static关键字修饰成员变量 有static修饰成员变量,说明这个成员变量是属于类的,这个成员变量称为类变量或者静态成员变量。 直接用 类名访问即可。因为类只有一个,所以静态成员变量在内存区域中也只存在一份。所有的对象都可以共享这个变量…

Anaconda安装-Ubuntu-Linux

1、进入Anaconda官网,以下载最新版本,根据自己的操作系统选择适配的版本。 2、跳过注册: 3、选择适配的版本: 4、cd ~/anaconda_download 5、bash Anaconda3-2024.10-1-Linux-x86_64.sh 6、按Enter或PgDn键滚动查看协议&…

Linux 配置NFS服务器

1. 开放/nfs/shared目录,供所有用户查阅资料 服务端 (1)安装nfs服务,nfs-utils包中包含rpcbind(rpc守护进程) [rootnode1-server ~]# yum install -y nfs-utils # nfs-utils包中包含rpcbind [rootnode…

塔能科技:用精准节能撬动社会效益的行业杠杆

在全球积极践行可持续发展理念的当下,能源高效利用与节能减排,已然成为各行各业实现高质量发展绕不开的关键命题。对企业来说,节能早已不是一道可做可不做的选择题,而是关乎生存与发展、社会责任与竞争力的必答题。塔能科技推出的…

Java 大视界 -- Java 大数据在自动驾驶高精度地图数据更新与优化中的技术应用(157)

💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…

nginx https配置

一.https配置 HTTPS 协议是由HTTP 加上TLS/SSL 协议构建的可进行加密传输、身份认证的网络协议,主要通过数字证书、加密算法、非对称密钥等技术完成互联网数据传输加密,实现互联网传输安全保护。 1.生成证书 openssl genrsa -des3 -out server.key 20…

每日一题洛谷P10901 [蓝桥杯 2024 省 C] 封闭图形个数c++

排序思想&#xff0c;只不过这时的排序与之前的略有不同&#xff0c;com函数中要先比较封闭图形再比较真实的大小&#xff0c;多了一步&#xff0c;但是原理还是一样的 #include<iostream> #include<algorithm> #include<vector> using namespace std; //统…

天锐蓝盾终端安全防护——企业终端设备安全管控

从办公室的台式电脑到员工手中的移动终端&#xff0c;这些设备不仅是工作的得力助手&#xff0c;更是企业数据的重要载体。然而&#xff0c;随着终端设备的广泛使用&#xff0c;安全风险也如影随形。硬件设备使用不当、数据随意传输等问题频发&#xff0c;使得企业数据面临着泄…