假设我们有这样的代码(暂时忘掉原型):
function A(){
var foo = 1;
this.method = function(){
return foo;
}
}
var a = new A();
是否在每次运行函数A时重新编译内部函数?或者这样做更好(以及为什么):
function method = function(){ return this.foo; }
function A(){
this.foo = 1;
this.method = method;
}
var a = new A();
还是javascript引擎足够聪明,不会每次都创建一个新的‘方法’函数?特别是谷歌的v8和node.js。
此外,欢迎任何关于何时使用哪种技术的一般性建议。在我的特定示例中,使用第一个示例非常适合,但我知道外部函数将被实例化多次。
发布于 2010-05-11 04:46:20
该方法不会重新编译。
每次调用外部方法时,Javascript解释器都会创建一个包含内部方法和局部变量的新闭包对象。
具体的实现取决于Javascript引擎。
发布于 2010-05-11 04:53:24
我猜它只编译一次...因为"this“关键字指的是执行上下文...因此,编译器不需要了解太多关于函数的知识就可以解释它。
此外,当您在函数的底部声明变量时,仍然可以在顶部访问该变量:
function test()
{
alert(hello);
// ...
var hello = 2;
}
函数也是如此。考虑到这两件事,我会相信它不会在每次调用A时都被重新编译。
麦克
发布于 2010-05-11 04:59:41
假设一个函数只是另一个对象,然后当你创建一个新的对象时,它只是一个旧对象的副本,其中一些数据变量发生了变化。您不需要重新解析对象的源代码即可实现此目的。一个很好的类比是C++中的functionoids,Lua中的function objects,而我并不了解很多其他语言。
https://stackoverflow.com/questions/2806324
复制相似问题