我想在循环中生成函数:
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)。
答案 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;
};
}