如何在coco中循环生成函数?

时间:2012-04-17 13:02:11

标签: javascript coco

我想在循环中生成函数:

for own k, v in t
  ctor::[k] = ->
    v(...)
    @

但是,coco似乎只生成一个函数并重用它:

var k, v, __ref, __own = {}.hasOwnProperty;
for (k in __ref = t) if (__own.call(__ref, k)) {
  v = __ref[k];
  ctor.prototype[k] = __fn;
}
function __fn(){
  v.apply(this, arguments);
  return this;
}

如何更改coco脚本以使输出如下:

var k, v, __ref, __own = {}.hasOwnProperty;
for (k in __ref = t) if (__own.call(__ref, k)) {
  v = __ref[k];
  ctor.prototype[k] = function() {
    v.apply(this, arguments);
    return this;
  }
}

澄清:使用coco我的意思是这种语言:http://satyr.github.com/coco/(coffeescript fork)。

1 个答案:

答案 0 :(得分:2)

这是一个功能。应该几乎总是避免在循环中直接写function。 JSLint禁止它说“不要在循环中创建函数。”

您的代码特别具有范围错误(动态创建的方法中的所有v将引用相同的值)。你应该在那里使用let绑定:

for own k, v in t
  let
    ctor::[k] = ->
      v ...
      this

编译为:

var k, v, __ref, __own = {}.hasOwnProperty;
for (k in __ref = t) if (__own.call(__ref, k)) {
  v = __ref[k];
  (__fn.call(this, k, v));
}
function __fn(k, v){
  ctor.prototype[k] = function(){
    v.apply(this, arguments);
    return this;
  };
}