gpt4 book ai didi

javascript - jQuery 单击处理程序中的范围

转载 作者:行者123 更新时间:2023-11-30 18:48:42 25 4
gpt4 key购买 nike

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

然后我在该行上设置了一个点击事件,这样当它被点击时,它会导航到我的数据对象中指定的 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 的引用,它是我的项目 for 循环的局部变量。当用户点击该行时,它如何知道它正在查看的是哪个项目?注册点击功能时是否以某种方式缓存?

其次,这个方法真的不好吗?我是在强制它在幕后做大量工作吗?

最佳答案

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

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

至于性能,这真的不是“工作负荷”,这是完全正常的。

关于javascript - jQuery 单击处理程序中的范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4603471/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com