gpt4 book ai didi

javascript - 模拟 'class' 时,为什么要在 .prototype 属性中而不是在构造函数本身中设置方法?

转载 作者:行者123 更新时间:2023-11-30 17:06:46 24 4
gpt4 key购买 nike

我正在尝试理解 JavaScript 中的“类”。

通常在 JavaScript 中模拟类看起来像这样:

function MyClass(someParameter) {
this.someValue = someParameter;
this.someOtherValue = "green";
}

MyClass.prototype.someMethod = function() {
console.log("Hello!");
};

虽然非函数成员是在构造函数内部设置的,但方法是在构造函数外部添加到构造函数的 .prototype 属性中。

我想知道为什么。为什么不像其他成员一样在构造函数中创建方法呢?含义:

function MyClass(someParameter) {
this.someValue = someParameter;
this.someOtherValue = "green";

this.someMethod = function() {
console.log("Hello!");
}
}

最佳答案

这里有一些要点:

  • 性能:每次创建实例时都会创建 Ctor 方法,而创建一次原型(prototype)方法并继承。这里使用原型(prototype)更好。
  • Ctor 方法可以访问函数内部的私有(private)对象,而原型(prototype)方法则不能。

关于javascript - 模拟 'class' 时,为什么要在 .prototype 属性中而不是在构造函数本身中设置方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27845479/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com