”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 为什么原型化为数组的 JavaScript 对象成员在类实例之间共享?

为什么原型化为数组的 JavaScript 对象成员在类实例之间共享?

发布于2024-12-22
浏览:868

Why do JavaScript Object Members Prototyped as Arrays Become Shared Across Class Instances?

原型化为数组的 JavaScript 对象成员:跨类实例共享

在 JavaScript 中对数组进行原型设计时,了解这些成员是共享的至关重要在所有类实例中。如果您习惯了私有对象成员,这种行为可能看起来违反直觉。

行为解释

JavaScript的原型机制允许对象从父对象继承属性和方法,称为原型。当您将数组定义为原型中的属性时,从该原型继承的所有对象都可以访问它。

示例脚本演示了此行为:

function Sandwich() {
    // Uncomment this to fix the problem
    //this.ingredients = [];
}

如果取消注释行,每个 Sandwich 实例都会有自己的私有成分数组。然而,当该行被注释掉后,所有实例共享相同的原型数组。

这意味着向cheesburger添加成分也会更新blt和spicy_chicken_sandwich的成分。为了防止这种情况,您必须在构造函数中定义成分数组,如下面更新的示例所示:

function Sandwich() {
    this.ingredients = [];
}

原型与实例

区分原型属性和实例属性至关重要。原型属性由从该原型继承的所有对象共享,而实例属性对于每个对象都是唯一的。

  • 将属性分配给原型以定义共享数据或方法。
  • 分配构造函数内实例的属性以定义特定于实例的数据。

代码修改以修复Behaviour

在示例脚本中,取消注释行 this.ingredients = []; Sandwich 构造函数中确保每个实例都按预期拥有自己的成分数组。

结论

了解 JavaScript 中原型数组的行为对于避免意外共享至关重要类实例之间。永远记住,应该是特定于实例的数据应该在构造函数中定义,而共享数据可以通过继承分配给原型。

最新教程 更多>
  • 查找当前执行JavaScript的脚本元素方法
    查找当前执行JavaScript的脚本元素方法
    如何引用当前执行脚本的脚本元素在某些方案中理解问题在某些方案中,开发人员可能需要将其他脚本动态加载其他脚本。但是,如果Head Element尚未完全渲染,则使用document.getElementsbytagname('head')[0] .appendChild(v)的常规方...
    编程 发布于2025-04-21
  • 如何从PHP中的数组中提取随机元素?
    如何从PHP中的数组中提取随机元素?
    从阵列中的随机选择,可以轻松从数组中获取随机项目。考虑以下数组:; 从此数组中检索一个随机项目,利用array_rand( array_rand()函数从数组返回一个随机键。通过将$项目数组索引使用此键,我们可以从数组中访问一个随机元素。这种方法为选择随机项目提供了一种直接且可靠的方法。
    编程 发布于2025-04-21
  • 手动触发桌面应用中的绘图事件方法
    手动触发桌面应用中的绘图事件方法
    [2 [2 油漆事件对于更新桌面应用程序中的图形用户界面(GUI)至关重要。 当动态更改面板上的文本之类的元素时,您需要手动触发重新粉刷以反映这些更改。本文详细介绍了如何完成此操作。 用于手动重新启动表格或控制类中的几种方法允许您强制重新涂抹: :此方法计划对控件进行重新涂漆。实际的重新绘制稍后发...
    编程 发布于2025-04-21
  • 如何检查对象是否具有Python中的特定属性?
    如何检查对象是否具有Python中的特定属性?
    方法来确定对象属性存在寻求一种方法来验证对象中特定属性的存在。考虑以下示例,其中尝试访问不确定属性会引起错误: >>> a = someClass() >>> A.property Trackback(最近的最新电话): 文件“ ”,第1行, attributeError:SomeClass实...
    编程 发布于2025-04-21
  • 使用jQuery如何有效修改":after"伪元素的CSS属性?
    使用jQuery如何有效修改":after"伪元素的CSS属性?
    在jquery中了解伪元素的限制:访问“ selector 尝试修改“:”选择器的CSS属性时,您可能会遇到困难。 This is because pseudo-elements are not part of the DOM (Document Object Model) and are th...
    编程 发布于2025-04-21
  • Java数组中元素位置查找技巧
    Java数组中元素位置查找技巧
    在Java数组中检索元素的位置 利用Java的反射API将数组转换为列表中,允许您使用indexof方法。 (primitives)(链接到Mishax的解决方案) 用于排序阵列的数组此方法此方法返回元素的索引,如果发现了元素的索引,或一个负值,指示应放置元素的插入点。
    编程 发布于2025-04-21
  • 如何将来自三个MySQL表的数据组合到新表中?
    如何将来自三个MySQL表的数据组合到新表中?
    mysql:从三个表和列的新表创建新表 答案:为了实现这一目标,您可以利用一个3-way Join。 选择p。*,d.content作为年龄 来自人为p的人 加入d.person_id = p.id上的d的详细信息 加入T.Id = d.detail_id的分类法 其中t.taxonomy =...
    编程 发布于2025-04-21
  • Python元类工作原理及类创建与定制
    Python元类工作原理及类创建与定制
    python中的metaclasses是什么? Metaclasses负责在Python中创建类对象。就像类创建实例一样,元类也创建类。他们提供了对类创建过程的控制层,允许自定义类行为和属性。在Python中理解类作为对象的概念,类是描述用于创建新实例或对象的蓝图的对象。这意味着类本身是使用类关...
    编程 发布于2025-04-21
  • 如何在php中使用卷发发送原始帖子请求?
    如何在php中使用卷发发送原始帖子请求?
    如何使用php 创建请求来发送原始帖子请求,开始使用curl_init()开始初始化curl session。然后,配置以下选项: curlopt_url:请求 [要发送的原始数据指定内容类型,为原始的帖子请求指定身体的内容类型很重要。在这种情况下,它是文本/平原。要执行此操作,请使用包含以下标头...
    编程 发布于2025-04-21
  • Go语言结构体深度解析
    Go语言结构体深度解析
    In Go, struct is an aggregate type used for defining and encapsulating data. It allows combining fields of different types. Structs can be seen as cus...
    编程 发布于2025-04-21
  • 如何使用FormData()处理多个文件上传?
    如何使用FormData()处理多个文件上传?
    )处理多个文件输入时,通常需要处理多个文件上传时,通常是必要的。 The fd.append("fileToUpload[]", files[x]); method can be used for this purpose, allowing you to send multi...
    编程 发布于2025-04-21
  • eval()vs. ast.literal_eval():对于用户输入,哪个Python函数更安全?
    eval()vs. ast.literal_eval():对于用户输入,哪个Python函数更安全?
    称量()和ast.literal_eval()中的Python Security 在使用用户输入时,必须优先确保安全性。强大的Python功能Eval()通常是作为潜在解决方案而出现的,但担心其潜在风险。 This article delves into the differences betwee...
    编程 发布于2025-04-21
  • 如何在Java的全屏独家模式下处理用户输入?
    如何在Java的全屏独家模式下处理用户输入?
    Handling User Input in Full Screen Exclusive Mode in JavaIntroductionWhen running a Java application in full screen exclusive mode, the usual event ha...
    编程 发布于2025-04-21
  • 如何在JavaScript对象中动态设置键?
    如何在JavaScript对象中动态设置键?
    在尝试为JavaScript对象创建动态键时,如何使用此Syntax jsObj['key' i] = 'example' 1;不工作。正确的方法采用方括号: jsobj ['key''i] ='example'1; 在JavaScript中,数组是一...
    编程 发布于2025-04-21
  • Python读取CSV文件UnicodeDecodeError终极解决方法
    Python读取CSV文件UnicodeDecodeError终极解决方法
    在试图使用已内置的CSV模块读取Python中时,CSV文件中的Unicode Decode Decode Decode Decode decode Error读取,您可能会遇到错误的错误:无法解码字节 在位置2-3中:截断\ uxxxxxxxx逃脱当CSV文件包含特殊字符或Unicode的路径逃...
    编程 发布于2025-04-21

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3