JQuery单击处理程序中的范围

时间:2011-01-05 11:19:46

标签: javascript jquery events javascript-events

我有一个函数,我可以获取一些数据,并将其插入到表的一行中。

然后我在该行上设置了一个click事件,这样当它被点击时,它会导航到我的数据对象中指定的URL:

$(data).each(function(i, item) {

    var row = $("<tr></tr>");
    tbody.append(row);

    // Add some cells into the row...
    var firstNameCol = $("<td>" + item.FirstName + "</td>");
    row.append(firstNameCol);

    // Set up click handler
    row.click(function() {
       window.location.href = item.DetailsURL;
    });
 });

现在这段代码运行正常,但它让我意识到我不确定事件是如何工作的。

该函数包含对item的引用,{{1}}是我的for循环项的本地变量。当用户点击该行时,它如何知道它正在查看哪个项目?是否在注册click函数时以某种方式缓存?

其次,这种方法真的很糟糕吗?我是否强迫它在幕后做大量工作?

修改添加了更多代码...

1 个答案:

答案 0 :(得分:2)

item是绑定时在该范围中可用的变量,因此您传递到.click()函数的匿名函数只获取它的副本(或引用,如果它是一个对象)当时

你可以称之为“缓存”,当然,它只是一个引用或它在那时获得的变量副本。 .each()创建一个闭包,你传递它的回调函数(function(i, item) {...}),并在那里(取决于它是否是一个对象,在这种情况下,你获得相同的引用)你得到自己的复制循环的迭代。

至于表现,这不是“工作量”,这是完全正常的。