3

我不确定如何描述我想要的东西。我想定义一个函数,其参数是本地 VALUE 而不是引用。

说我有要创建的对象列表

for(i = 0; i < 10; i++){
  var div = document.createElement("div");
  div.onclick = function(){alert(i);};
  document.appendChild(div);
}

现在我相信这个例子无论我点击什么div,它都会提示“10”;因为这是变量 i 的最后一个值;

有没有办法/如何创建一个函数,其参数是我指定函数时的值......如果这有任何意义。

4

2 回答 2

5

您需要在另一个函数中创建该函数。

例如:

div.onclick = (function(innerI) {
    return function() { alert(innerI); }
})(i);

此代码创建一个函数,该函数接受一个参数并返回一个使用该参数的函数。由于外部函数的参数是按值传递的,因此可以解决您的问题。

使外部函数成为单独的命名函数通常更清楚,如下所示:

function buildClickHandler(i) {
    return function() { alert(i); };
}

for(i = 0; i < 10; i++){
    var div = document.createElement("div");
    div.onclick = buildClickHandler(i);
    document.appendChild(div);
}
于 2010-03-16T00:10:56.853 回答
0

您可以使用匿名函数:

for(i = 0; i < 10; i++){
    (function(i){
        var div = document.createElement("div");
        div.onclick = function(){alert(i);};
        document.appendChild(div);
    })(i)
}
于 2010-03-16T00:12:24.173 回答