当前位置:首页 > 文章列表 > 文章 > 前端 > 深入探讨 JavaScript 的原型链和函数的基础作用

深入探讨 JavaScript 的原型链和函数的基础作用

来源:dev.to 2024-11-17 14:18:59 0浏览 收藏

golang学习网今天将给大家带来《深入探讨 JavaScript 的原型链和函数的基础作用》,感兴趣的朋友请继续看下去吧!以下内容将会涉及到等等知识点,如果你是正在学习文章或者已经是大佬级别了,都非常欢迎也希望大家都能给我建议评论哈~希望能帮助到大家!

深入探讨 JavaScript 的原型链和函数的基础作用

javascript 采用独特的继承方法,与 java 或 c++ 等传统的面向对象语言不同。 javascript 使用基于原型的继承模型,而不是依赖基于类的继承。该模型以语言的函数及其原型属性为基础,构成了对象如何继承行为的基础。为了理解为什么 javascript 的继承是这样设计的,以及它是如何通过原型链实现继承的,我们必须探索函数、原型和原型链内部工作原理之间的关系。

1. 基金会:作为带有原型链接的构造函数

在 javascript 中,函数不仅仅是可执行代码块;它们拥有独特的属性,这些属性使它们成为该语言的面向对象功能的基础。 javascript 中的每个函数(箭头函数除外)自动具有一个原型属性,它是一个用作该函数创建的实例蓝图的对象。这是一个显着特征 - 大多数其他面向对象语言依赖类而不是函数作为继承的构建块。

当函数用作构造函数时(通过 new 关键字),javascript 会创建一个新对象,将其链接到函数的原型,并将新对象分配为构造函数内的上下文 (this)。这意味着添加到函数原型的任何属性或方法都可以被从该函数创建的所有实例访问,从而建立共享继承模型。

为什么是函数?

使用函数作为构造函数并将继承属性附加到其原型上,使 javascript 变得灵活且轻量级。通过在函数而不是类上构建继承,javascript 允许继承而不需要严格的类结构。这种灵活性对于 javascript 的初始设计尤其重要,因为它是一种用于动态、基于 web 的脚本语言,需要轻量级、面向对象的行为。

2. 理解原型链:一系列链接的原型

原型链是 javascript 用于搜索属性和方法的机制。创建对象时,javascript 通过名为 proto 的内部引用自动将其链接到另一个对象(函数的原型对象)。这形成了一个链状结构,其中对象通过链接到其他对象来继承属性,从而创建“原型链”。

链条如何运作

直接访问优先:当您尝试访问对象上的属性时,javascript 首先检查该属性是否直接存在于该对象上。

原型查找:如果在对象本身上找不到属性,javascript 会查找链,检查 proto 引用的对象原型(函数的原型属性)。

遍历链:如果仍未找到属性,javascript 会继续查找每个原型的 proto,有效地遍历对象链,直到到达末尾(即,object.prototype,顶级原型)。

链结束:如果在原型链中的任何位置都找不到该属性,javascript 将返回 undefined。

这种结构使 javascript 对象能够继承共享方法和属性而无需重复,从而提供了一种节省内存的方式来实现继承。

为什么是链条?

链允许 javascript 动态地实现继承,而无需预定义的类结构。每个对象都可以有自己的原型链接,因此可以在运行时设置继承层次结构。与传统的基于类的模型相比,这种结构使得 javascript 的原型继承变得如此灵活和适应性强。

3. 通过构造函数进行实际继承

要了解这个基于原型的系统的强大功能,请考虑一个简单的示例,其中两个构造函数(animal 和 dog)使用原型链来共享行为。

function animal() {}
animal.prototype.speak = function() {
    return "some generic sound";
};

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

// set dog’s prototype to inherit from animal’s prototype
dog.prototype = object.create(animal.prototype);
dog.prototype.constructor = dog; // correcting constructor reference

// adding dog-specific behavior
dog.prototype.bark = function() {
    return `${this.name} barks!`;
};

const mydog = new dog("rex");
console.log(mydog.speak());  // output: "some generic sound"
console.log(mydog.bark());   // output: "rex barks!"
in this example:

dog.prototype被设置为继承自animal.prototype,允许dog实例继承speak方法。
当调用 mydog.speak() 时,javascript 会查找 mydog 的原型链并在 animal.prototype 上找到 talk。
此设置使 dog 实例能够说话(来自动物)和吠叫(来自狗),而无需重复代码。
这个例子展示了 javascript 的原型链如何允许灵活高效的继承,使用函数作为定义和共享行为的基础。

4. 函数、原型和共享内存

原型链的一个关键优势是内存效率。当您向函数原型添加方法时,该函数创建的所有实例都会共享这些方法,而不是创建副本。此模型与具有经典继承的语言不同,在经典继承中,每个对象通常都有自己的方法副本,从而导致更大的内存使用量。

例如,在 dog 示例中,向 animal.prototype 添加 talk 意味着每个 dog 实例都可以调用spoke,而无需创建它的单独副本。这种共享访问对于内存管理至关重要,尤其是在内存中可能存在许多对象的 web 应用程序中。

5. object.create 的替代方案

javascript 还提供了 object.create() 方法,该方法允许您创建具有特定原型的对象,而无需构造函数。虽然这种方法不需要函数,但它仍然依赖于原型的概念,强调了原型链对于 javascript 继承的重要性。

const animal = {
    speak: function() {
        return "Some generic sound";
    }
};

const dog = Object.create(animal);
dog.bark = function() {
    return "Woof!";
};

console.log(dog.speak()); // Output: "Some generic sound"
console.log(dog.bark());  // Output: "Woof!"

这里,dog通过原型链继承自animal,使其能够访问speak。虽然我们没有使用构造函数,但继承过程仍然基于原型链,并遵循相同的通过 proto.

查找的原则

6. 为什么 javascript 的原型链很重要

原型链是 javascript 灵活性的基石。通过允许通过函数和原型链接建立继承,javascript 避免了经典继承的僵化,并提供了更流畅、适应性更强的继承系统。这种适应性是 javascript 的关键优势之一,尤其是在 web 开发等环境中,快速迭代、轻量级结构和内存效率至关重要。

原型链使开发人员能够控制继承,让他们可以动态设置层次结构并有效地重用属性。这就是为什么,即使引入了 es6 类(它为基于原型的继承提供了语法糖),底层原型链仍然是 javascript 处理继承的基础。

总之

javascript 的继承模型以函数和原型为中心,使用原型链进行属性查找和共享行为。函数提供原型属性,形成 javascript 遍历以进行继承的链接对象链。这种方法比基于类的继承更灵活、更节省内存,使得 javascript 特别适合动态应用程序。因此,原型链不仅是一个基本概念,而且是一个赋予 javascript 在面向对象编程中独特能力和适应性的功能。

以上就是《深入探讨 JavaScript 的原型链和函数的基础作用》的详细内容,更多关于的资料请关注golang学习网公众号!

版本声明
本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
当今最复杂的椭圆曲线找到了!29个独立有理点打破18年记录当今最复杂的椭圆曲线找到了!29个独立有理点打破18年记录
上一篇
当今最复杂的椭圆曲线找到了!29个独立有理点打破18年记录
Win11怎么开启色盲模式 Win11怎么开启色盲模式操作
下一篇
Win11怎么开启色盲模式 Win11怎么开启色盲模式操作
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • AI Make Song:零门槛AI音乐创作平台,助你轻松制作个性化音乐
    AI Make Song
    AI Make Song是一款革命性的AI音乐生成平台,提供文本和歌词转音乐的双模式输入,支持多语言及商业友好版权体系。无论你是音乐爱好者、内容创作者还是广告从业者,都能在这里实现“用文字创造音乐”的梦想。平台已生成超百万首原创音乐,覆盖全球20个国家,用户满意度高达95%。
    26次使用
  • SongGenerator.io:零门槛AI音乐生成器,快速创作高质量音乐
    SongGenerator
    探索SongGenerator.io,零门槛、全免费的AI音乐生成器。无需注册,通过简单文本输入即可生成多风格音乐,适用于内容创作者、音乐爱好者和教育工作者。日均生成量超10万次,全球50国家用户信赖。
    21次使用
  •  BeArt AI换脸:免费在线工具,轻松实现照片、视频、GIF换脸
    BeArt AI换脸
    探索BeArt AI换脸工具,免费在线使用,无需下载软件,即可对照片、视频和GIF进行高质量换脸。体验快速、流畅、无水印的换脸效果,适用于娱乐创作、影视制作、广告营销等多种场景。
    23次使用
  • SEO标题协启动:AI驱动的智能对话与内容生成平台 - 提升创作效率
    协启动
    SEO摘要协启动(XieQiDong Chatbot)是由深圳协启动传媒有限公司运营的AI智能服务平台,提供多模型支持的对话服务、文档处理和图像生成工具,旨在提升用户内容创作与信息处理效率。平台支持订阅制付费,适合个人及企业用户,满足日常聊天、文案生成、学习辅助等需求。
    23次使用
  • Brev AI:零注册门槛的全功能免费AI音乐创作平台
    Brev AI
    探索Brev AI,一个无需注册即可免费使用的AI音乐创作平台,提供多功能工具如音乐生成、去人声、歌词创作等,适用于内容创作、商业配乐和个人创作,满足您的音乐需求。
    25次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码