- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个关于 JS 原型(prototype)的问题:
如果我有以下构造函数:
function Person(name) {
if (!(this instanceof Person))
return new Person(name);
this.name = name;
}
Person.prototype.sayHello = function() {
console.log("Hello from " + this.name);
}
这里我有一个方法 sayHello
绑定(bind)到 Person 的原型(prototype),它的内存效率更高:
function Person(name) {
if (!(this instanceof Person))
return new Person(name);
this.name = name;
this.sayHello = function() {
console.log("Hello from " + this.name);
}
}
一瞥:
原型(prototype)人物:
非原型(prototype)人:
如您所见,对 sayHello
Function 的引用将在所有创建的人中“共享”,而不是仅为每个实例化的人创建一个新的 Function。当 sayHello()
被 那个特定的人。
现在,另一个变体:
function Person(name) {
if (!(this instanceof Person))
return new Person(name);
this.name = name;
this.__proto__.sayHello = function() {
console.log("Hello from " + this.name);
}
}
并且输出与 Person.prototype.sayHello
相同,这意味着 sayHello
在不同的人之间共享。
但这两种方法有区别吗?我猜不是,因为:
Person.prototype === bob.__proto__//true
真的,什么时候应该使用前者(Person.prototype.*
在构造函数外)而不是后者(this.__proto__.*
在构造函数内)函数)?
最佳答案
扩展 Felix 的评论。
版本如下:
this.__proto__.sayHello = function() {
console.log("Hello from " + this.name);
}
不应使用。
每次调用封闭构造函数时,上面的代码也将运行,创建该匿名函数的新副本,并覆盖当前保存在原型(prototype)<中的引用
.
任何恰好包含对该函数先前实例的引用的代码都将继续指向该旧版本。
在内存效率方面,它与编写 this.sayHello = function(...)
非常相似,因为没有一个实例实际上共享函数的相同副本。在代码效率方面,它可以说更糟糕(尽管等同于使用 Person.prototype.sayHello = ...)
,因为每次调用都需要在原型(prototype)链上向上移动。
关于JavaScript 原型(prototype)继承这段代码是否有区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29672645/
我觉得 for(int i = 0; i < 2; i++) 和 for(int i = 0; i < 2; ++i) 不应该做同样的事情。对于第二个例子,从循环开始 i 应该等于 1 对我来说更符合
我试图牢牢掌握异常情况,以便改进我的conditional loop implementation .为此,我进行了各种实验,扔东西,看看会被抓到什么。 这个让我惊喜不已: % cat X.hs mo
我只是想回答一个问题,但我遇到了一些我不明白的事情!为什么如果我在文件中使用内联 CSS 或 CSS,如本例中的颜色,结果就不一样! 代码相同,但第一段是绿色,第二段是红色! 我真的不明白为什么? 谢
我目前正在学习 CSS 并进行试验,我偶然发现了输出中的这种差异。所以这是代码: .red-text { color: red;
"""module a.py""" test = "I am test" _test = "I am _test" __test = "I am __test" ============= ~ $ p
在向 Firestore 写入文档时,我经常看到 serverTimestamp() 标记和 new Date() 对象之间的差异不为零。 差异范围从几 秒到几十 分钟。 他们不是在做同样的事情吗?
据我了解,2.675 和 numpy.float64(2.675) 都是相同的数字。然而,round(2.675, 2) 给出 2.67,而 round(np.float64(2.675), 2) 给
问题本身的描述很简单。我正在测试 C++11 中 std::thread 库和 boost::thread 库的区别。 这些的输出: #include #include #include int
我只是想将文本文件读入 pyspark RDD,我注意到 sqlContext.read.load 之间的巨大差异和 sqlContext.read.text . s3_single_file_inp
SC.exe 和 InstallUtil 都可以安装/卸载 Windows 服务。但它们的工作方式似乎并不相同。 有什么区别? 例如,InstallUtil 失败(找不到某些文件或依赖项错误),而 S
我认为Thread对象就像是带有名称和静态Thread.CurrentThread()的抽象对象,就像访问Thread对象的方式一样。显然,这是错误的假设。。是这样的吗?
我认为Thread对象就像是带有名称和静态Thread.CurrentThread()的抽象对象,就像访问Thread对象的方式一样。显然,这是错误的假设。。是这样的吗?
我是一名优秀的程序员,十分优秀!