首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >javascript中的闭包是否已重新编译?

javascript中的闭包是否已重新编译?
EN

Stack Overflow用户
提问于 2010-05-11 04:42:46
回答 4查看 590关注 0票数 16

假设我们有这样的代码(暂时忘掉原型):

代码语言:javascript
复制
function A(){
  var foo = 1;
  this.method = function(){
    return foo;
  }
}
var a = new A();

是否在每次运行函数A时重新编译内部函数?或者这样做更好(以及为什么):

代码语言:javascript
复制
function method = function(){ return this.foo; }
function A(){
  this.foo = 1;
  this.method = method;
}
var a = new A();

还是javascript引擎足够聪明,不会每次都创建一个新的‘方法’函数?特别是谷歌的v8和node.js。

此外,欢迎任何关于何时使用哪种技术的一般性建议。在我的特定示例中,使用第一个示例非常适合,但我知道外部函数将被实例化多次。

EN

回答 4

Stack Overflow用户

发布于 2010-05-11 04:46:20

该方法不会重新编译。

每次调用外部方法时,Javascript解释器都会创建一个包含内部方法和局部变量的新闭包对象。

具体的实现取决于Javascript引擎。

票数 2
EN

Stack Overflow用户

发布于 2010-05-11 04:53:24

我猜它只编译一次...因为"this“关键字指的是执行上下文...因此,编译器不需要了解太多关于函数的知识就可以解释它。

此外,当您在函数的底部声明变量时,仍然可以在顶部访问该变量:

代码语言:javascript
复制
function test()
{
  alert(hello);
  // ...
  var hello = 2;
}

函数也是如此。考虑到这两件事,我会相信它不会在每次调用A时都被重新编译。

麦克

票数 0
EN

Stack Overflow用户

发布于 2010-05-11 04:59:41

假设一个函数只是另一个对象,然后当你创建一个新的对象时,它只是一个旧对象的副本,其中一些数据变量发生了变化。您不需要重新解析对象的源代码即可实现此目的。一个很好的类比是C++中的functionoids,Lua中的function objects,而我并不了解很多其他语言。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2806324

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档