调用的单击处理程序过多
Too many click handlers being called
我正在使用以下函数,使用数组消息动态地用一些文本和按钮填充div:
var populateMessages = function(messages){
for (var index in messages){
(function(){
var id = index;
$("#messages").append(messages[index]["title"])
$("#messages").append("<button>Open</button><br/>").click(function(){console.log(message["id"])})
}())
}
};
此代码使用文本和按钮正确地填充div。问题是,如果我点击任何一个按钮,所有按钮的点击处理程序都会启动。因此,有了两个按钮,如果我点击第一个按钮,它应该记录"0",如果我单击第二个按钮,应该记录"1"。相反,如果我点击其中一个,它会记录"0 1">
我对Javascript不是很了解,所以我不知道问题出在哪里。
的返回值
$("#messages").append("<button>Open</button><br/>")
是#messages
,而不是添加的按钮。因此,每次在循环中,您都要向#messages
添加另一个单击处理程序,而不是按钮。
尝试:
$.each(messages, function(index, message) {
$("#messages").append(message.title);
$("<button>Open</button>").click(function() {
console.log(message.id);
}).appendTo("#messages");
$("#messages").append("<br/>");
});
$("#messages").append("<button>Open</button><br/>")
返回#messages
而不是button
,因此您将单击事件设置为#message
。
试试这个:
$("#messages").append("<button>Open</button><br/>").find("button:last").click(/blabla/)
相关文章:
- keyup事件处理程序更改焦点不适用于快速键入
- Webpack/Rect:遵循egghead.io教程,但出现错误:您可能需要一个合适的加载程序来处理此文件类型
- 提示使用服务器端事件处理程序激活JavaScript
- 将事件处理程序绑定到任何可能的事件
- 正在将事件处理程序添加到不存在的类
- 在AJAX回调和呈现PIXIJS之间处理程序流时遇到了问题
- Adobe Edge:动画完成时添加onComplete处理程序
- 是否可以从输入处理程序中确定输入的类型
- 在MVVM视图模型中处理应用程序范围的元素
- 在循环中附加事件处理程序时出现浏览器性能问题
- 在同一个javascript事件处理程序中调用不同的函数
- 有没有一种方法可以让内联事件处理程序在元素创建后立即执行
- 检查事件处理程序参数
- 实现延迟的jquery更改事件处理程序
- 如何使用Python/Selenium网络驱动程序处理Angularjs/Javascript下拉列表
- 在 AJAX 完成之前,不要让其他处理程序处理
- 如何使用硒铬驱动程序处理地理位置弹出窗口
- 如何使用硒网络驱动程序处理 onblur 事件
- 是否有一种方法为chrome打包应用程序处理Http BasicAuthentication
- Ajax加载程序处理问题