深入理解 JavaScript 对象原型,解密原型链之谜(下)

在这里插入图片描述

🤍 前端开发工程师、技术日更博主、已过CET6
🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1
🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》
🍚 蓝桥云课签约作者、上架课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

  • 三、利用对象原型进行扩展🎯
    • 讲解如何在原型上添加方法和属性
    • 展示如何通过原型实现共享属性和方法
  • 四、总结与展望🎓
    • 总结对象原型的重要性和应用场景
    • 展望未来可能的发展方向
  • 参考资料

三、利用对象原型进行扩展🎯

讲解如何在原型上添加方法和属性

在 JavaScript 中,可以在原型上添加方法和属性,这样所有的对象都可以共享这些方法和属性。以下是添加方法和属性的步骤:

  1. 创建一个原型对象:首先,需要创建一个原型对象,这个对象将包含共享的属性和方法。可以使用 Object.create() 方法创建一个新对象,并指定一个原型。
const prototype = Object.create(Object.prototype);

在上面的示例中,我们创建了一个新对象 prototype,它的原型是 Object.prototype

  1. 为原型添加属性和方法:可以为原型对象添加属性和方法,从而使得所有对象都可以共享这些属性和方法。
prototype.greeting = "Hello";
prototype.sayHello = function() {console.log(`${this.greeting}, world!`);
};

在上面的示例中,我们为 prototype 添加了 greetingsayHello 属性和方法。

  1. 创建对象并继承原型:可以使用 Object.create() 方法创建一个新对象,并指定一个原型。这样,新对象就会从指定的原型上继承属性和方法。
const person = Object.create(prototype);
person.name = "Alice";

在上面的示例中,我们创建了一个新对象 person,并指定它的原型为 prototype。因此,person 会从 prototype 上继承 greetingsayHello 属性和方法。

  1. 使用原型链访问属性和方法:当访问一个对象的属性或方法时,如果该对象本身没有这个属性或方法,JavaScript 会在该对象的原型上查找。
console.log(person.greeting); // 输出:"Hello"
person.sayHello(); // 输出:"Hello, world!"

在上面的示例中,我们访问了 person 对象的 greetingsayHello 属性和方法,这些属性和方法是从 prototype 上继承的。

总之,在 JavaScript 中,可以通过在原型上添加方法和属性,使得所有的对象都可以共享这些方法和属性,从而减少内存占用和提高性能。

展示如何通过原型实现共享属性和方法

在 JavaScript 中,可以通过原型(Prototype)来共享属性和方法。下面是一个简单的例子来说明这一点:

function Person(name) {this.name = name;
}Person.prototype.greeting = "Hello";
Person.prototype.sayHello = function() {console.log(`${this.greeting}, my name is ${this.name}`);
};function Employee(name, employeeId) {Person.call(this, name);this.employeeId = employeeId;
}Employee.prototype = Object.create(Person.prototype);
Employee.prototype.constructor = Employee;Employee.prototype.sayHello = function() {console.log(`${this.greeting}, my name is ${this.name} and my employee ID is ${this.employeeId}`);
};var person = new Person("Alice");
person.sayHello(); // 输出:Hello, my name is Alicevar employee = new Employee("Bob", "E123");
employee.sayHello(); // 输出:Hello, my name is Bob and my employee ID is E123

在这个例子中,我们创建了两个构造函数:PersonEmployeeEmployee 继承了 Person。我们通过 Object.create(Person.prototype) 创建了一个新的原型对象,这个新原型对象继承了 Person 的原型。然后我们将 Employee 的原型指向这个新创建的原型对象。这样,Employee 就继承了 Person 的属性和方法。

我们还在 Employee 的原型上重写了 sayHello 方法,使其输出更具体的信息。当我们创建一个 Employee 实例并调用 sayHello 方法时,由于继承了 PersonsayHello 方法,所以可以正常调用并输出结果。

这个例子展示了如何通过原型在不同的对象之间共享属性和方法。

四、总结与展望🎓

总结对象原型的重要性和应用场景

在 JavaScript 中,对象原型是一种重要的机制,它允许对象继承其他对象的属性和方法,从而实现代码的复用和减少内存的消耗。原型链是 JavaScript 中对象继承属性和方法的一种机制,它使得我们可以共享通用的属性和方法,从而减少内存占用和提高性能。

对象原型的应用场景包括:

  1. 属性和方法的继承:对象原型允许我们在一个对象上添加或修改属性和方法,然后在其派生对象中继承这些属性和方法。这种机制可以减少代码的重复,提高代码的可维护性和可读性。

  2. 原型链继承:在 JavaScript 中,所有的对象都是通过原型链来访问属性和方法的。当我们访问一个对象的属性或方法时,如果该对象本身没有这个属性或方法,JavaScript 会在该对象的原型上查找。这种查找过程形成了一条原型链。原型链继承是指在原型链上查找属性和方法的过程。

  3. 原型链中断:如果到达原型链的末尾仍然没有找到指定的属性和方法,那么查找过程将会中断,并抛出一个 ReferenceError 错误。

总之,对象原型和原型链是 JavaScript 中对象继承属性和方法的重要机制,它们在提高代码复用性和减少内存消耗方面发挥着重要作用。在实际编程中,了解和熟练掌握对象原型和原型链的用法对于提高代码质量和效率具有重要意义。

展望未来可能的发展方向

JavaScript 的原型和原型链机制已经非常成熟,在未来的发展中,可能会有一些改进和优化。以下是一些可能的发展方向:

  1. 更简洁的原型语法:目前,创建原型对象需要使用 Object.create() 方法,未来可能会引入更简洁的语法来创建原型对象。
const prototype = {greeting: "Hello",sayHello: function() {console.log(`${this.greeting}, world!`);}
};

在上面的示例中,我们创建了一个原型对象 prototype,并为其添加了 greetingsayHello 属性和方法。未来可能会引入一种更简洁的语法来创建原型对象,例如:

const prototype = {greeting: "Hello",sayHello() {console.log(`${this.greeting}, world!`);}
};
  1. 更灵活的原型链继承:在当前的 JavaScript 规范中,原型链继承有一些限制,例如不能直接修改原型对象的属性。未来可能会引入一些新的方法来更灵活地处理原型链继承。

  2. 优化原型链查找性能:在当前的实现中,当访问一个对象的属性或方法时,如果该对象本身没有这个属性或方法,JavaScript 会在该对象的原型上查找。这种查找过程可能会导致性能问题。未来可能会引入一些优化措施来提高原型链查找的性能。

总之,在未来的 JavaScript 发展中,可能会对原型和原型链机制进行一些改进和优化,以提高代码的可读性和性能。

参考资料

MDN Web Docs: Object.prototype
《JavaScript 高级程序设计》

希望这篇文章能够帮助到你!如果你有任何问题或建议,欢迎在评论区留言。📃📋

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

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

相关文章

VScode连接远端服务器一直输入密码解决方法

文章目录 1 关闭远程连接2打开命令面板3 输入remote-ssh: kill vs code server on host… 1 关闭远程连接 2打开命令面板 3 输入remote-ssh: kill vs code server on host… remote-ssh: kill vs code server on host… 然后一路回车(选中出问题的主机),输一遍密码…

缓存一致性问题的解决策略

缓存一致性问题的背景和概念介绍 在一个系统中,我们通常使用数据库来存储数据,以保证数据的持久性。但是,由于数据库的读写速度相对较慢,如果每次请求都直接访问数据库,会降低系统的响应速度。为了提高系统的性能&…

《TCP/IP详解 卷一》第7章 防火墙和NAT

7.1 引言 NAT通常改变源IP和源端口,不改变目的IP和目的端口。 7.2 防火墙 常用防火墙: 包过滤防火墙(packet-filter firewall) 代理防火墙(proxy firewall) 代理防火墙作用: 1. 通过代理服务…

Spring全面精简总结

Spring两大核心功能:IOC控制反转、AOP面向切面的编程 控制反转(loC,Inversion of Control),是一个概念,是一种思想。指将传统上由程序代码直接操控的对象调用权交给容器,通过容器来实现对象的装配和管理。控制反转就是…

雾锁王国Enshrouded服务器几核几G够用?

雾锁王国/Enshrouded服务器CPU内存配置如何选择?阿里云服务器网aliyunfuwuqi.com建议选择8核32G配置,支持4人玩家畅玩,自带10M公网带宽,1个月90元,3个月271元,幻兽帕鲁服务器申请页面 https://t.aliyun.com…

three中界面交互gui.js库的使用

gui.js库(可视化改变三维场景) dat.gui.js说白了就是一个前端js库,对HTML、CSS和JavaScript进行了封装,学习开发的时候,借助dat.gui.js可以快速创建控制三维场景的UI交互界面,你打开课件中案例源码体验一下就能感受到。 学习dat…

C++笔记(二)--- 继承和组合

目录 C三种继承方式 构造函数 析构 继承 public继承 protected继承 private继承 组合 访问权限 构造/析构函数调用顺序 初始化 总结 C三种继承方式 C有三种继承方式:public protected private 属性方式为 class [派生类名称] : [继承方式] [继…

嵌入式驱动学习第一周——git的使用

前言 本文主要介绍git的使用,包括介绍git,gitee,以及使用gitee创建仓库并托管代码 嵌入式驱动学习专栏将详细记录博主学习驱动的详细过程,未来预计四个月将高强度更新本专栏,喜欢的可以关注本博主并订阅本专栏&#xf…

StarRocks实战——多维分析场景与落地实践

目录 一、OLAP 系统历史背景 1.1 历史背景与痛点 1.2 组件诉求 二、StarRocks 的特点和优势 2.1 极致的查询性能 2.2 丰富的导入方式 2.3 StarRocks 的优势特点 三、多维分析的运用场景 3.1 实时计算场景 / 家长监控中心 3.2 实时更新模型选择 3.2.1 更新模型UNIQU…

一般情况下,硬件中使用Repeating Sequence出现波形很奇怪就是数据的周期频率和mcu运行的频率不一致导致的

一般情况下,出现波形很奇怪就是数据的周期频率和mcu运行的频率不一致导致的 把timer values 修改为0 1就好了,如果是0,0.1就不行,不会有下面的波形

15:00面试,15:06就出来了,问的问题过于变态了。。。

我从一家小公司转投到另一家公司,期待着新的工作环境和机会。然而,新公司的加班文化让我有些始料未及。虽然薪资相对较高,但长时间的工作和缺乏休息使我身心俱疲。 就在我逐渐适应这种高强度的工作节奏时,公司突然宣布了一则令人…

新加坡大带宽服务器概览

随着全球互联网的迅猛发展,服务器作为支撑网络应用的重要基础设施,扮演着越来越重要的角色。新加坡,作为亚洲四小龙之一,其服务器市场也备受关注。特别是新加坡的大带宽服务器,更是受到了众多企业和个人的青睐。那么&a…

Python 实现Excel自动化办公(上)

在Python 中你要针对某个对象进行操作,是需要安装与其对应的第三方库的,这里对于Excel 也不例外,它也有对应的第三方库,即xlrd 库。 什么是xlrd库 Python 操作Excel 主要用到xlrd和xlwt这两个库,即xlrd是读Excel &am…

水印相机小程序源码

水印相机前端源码,本程序无需后端,前端直接导入即可,没有添加流量主功能,大家开通后自行添加 源码搜索:源码软件库 注意小程序后台的隐私权限设置,前端需要授权才可使用 真实时间地址拍照记录&#xff0c…

无铅/低ESR 32.768 kHz晶体单元 FC3215AN

概述 FC3215AN是一款低ESR和紧凑的32.768 kHz晶体单元,具有坚固的无铅金属盖接缝密封封装。它配备了基于我们几十年来音叉晶体器件的内部设计和生产技术专业知识而重新设计的晶体元件。它非常适合需要低电流消耗的应用,例如电池供电的物联网设备。它还支…

Python分支和循环结构及其应用(文末送书)

一、分支结构 应用场景 我们写的Python代码都是一条一条语句顺序执行,这种代码结构通常称之为顺序结构。然而仅有顺序结构并不能解决所有的问题。 if语句的使用 在Python中,要构造分支结构可以使用if、elif和else关键字。所谓关键字就是有特殊含义的…

[算法沉淀记录] 排序算法 —— 选择排序

排序算法 —— 选择排序 基本概念 选择排序是一种简单的排序算法,它的工作原理是每次从待排序的列表中选择最小(或最大)的元素,将其与列表中的第一个位置交换,然后继续对剩余的元素进行排序,直到整个列表…

Vue3 toRaw 与 markRaw

1、toRaw 作用:返回将reactive,readonly, shallowReactive 或者 shallowReadonly 这个四个方法包裹的原始数据。如下图 toRaw返回的数据与包裹之前的数据一个地址值数据,也就是两个数据是相等。 注意:toRaw不能乱用…

在Ubuntu上为ARM 8处理器安装Python 3.10.4虚拟环境指南

在Ubuntu上为ARM 8处理器安装Python 3.10.4虚拟环境指南 安装Anaconda或Miniconda: 首先,您需要从官方网站下载适用于ARM架构的Anaconda或Miniconda安装包。下载完成后,在终端中使用bash Anaconda3-2019.10-Linux-armv8.sh(文件…

Android java基础_异常

一.异常的概念 在Java中,异常(Exception)是指程序执行过程中可能出现的不正常情况或错误。它是一个事件,它会干扰程序的正常执行流程,并可能导致程序出现错误或崩溃。 异常在Java中是以对象的形式表示的,…