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

标签 javascript jquery events jquery-events

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

然后我在该行上设置了一个点击事件,这样当它被点击时,它会导航到我的数据对象中指定的 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/

相关文章:

javascript - 将 angular2 添加到现有的 Nodejs 应用程序中

javascript - 样式自定义日期选择器

javascript - 向下滚动按钮动画不起作用

javascript - jqtransform 表单选择器(onchange)问题!

javascript - 如何在 Angular 中使用 controllerAs 语法时监听 $destroy

iphone - UiTextField 事件

javascript - 在范围输入的缩略图内放置一个值

javascript - 当我使用 "await"创建函数的变量时,该函数立即运行还是仅在我调用该变量时运行?

javascript - 如何使用大括号通过 "shelljs"在单个命令中创建多个目录?

javascript - 如何禁用(防止)移动网站水平滑动?