jQuery绑定事件不执行但alert后可以正常执行
作者:
这篇文章主要为大家解决下为什么jQuery绑定事件不执行而alert后可以正常执行,需要的朋友可以参考下
因为我不知道怎么描述这个问题,故标题起的这么坑爹
主要过程是这样的,今天我写一个类似于百度知道那样有提问答案的页面,所有的数据都是页面第一次加载时通过ajax得到的
希望实现的效果是提问者可以通过店家每个答案后面的星星符号选择采纳此答案,被采纳的答案星星图标会变成全黑的。
开始我是这样写的
$('.choose_right_answer').bind('click',function(){
if(currentUser==questioner) {
if ($(this).attr("src") == "img/star_fav_empty.png")
$(this).attr("src", "img/star_fav.png");
else
$(this).attr("src", "img/star_fav_empty.png");
}
});
.choose_right_answer是每个星星class名
运行之后点击星星没有反应
于是我在上面所示代码段之前加上了一个alert("test")
此时加载页面后弹出对话框test之后,星星图标上绑定的事件可以正常执行。
上网搜了一通答案,得到的结果是由于所有的这些答案的节点都是动态生成的,因此可能在这些节点还没有执行完时,就执行了事件绑定,以至于并没有真正将事件绑定到生成的这些答案的节点。
而加上alert之后,可以明显看到,alert语句在所有数据得到后才执行,确保了事件绑定在数据加载完之后执行,因此事件成功绑定到了各个回答上。
http://img.blog.csdn.net/20140531202827265
解决方法,使用jQuery中的on来绑定事件
$("#answer_wrap").on('click','.choose_right_answer',function(){
if(currentUser==questioner) {
if ($(this).attr("src") == "img/star_fav_empty.png")
$(this).attr("src", "img/star_fav.png");
else
$(this).attr("src", "img/star_fav_empty.png");
}
});
answer_wrap是所有回答所在块的id
所有在这个块里class为choose_right_answer的元素如果发生点击则事件冒泡到answer_wrap,执行对应函数,其余在这个块中的元素发生点击事件则忽略
这样就可以解决动态加载数据中事件绑定的问题
主要过程是这样的,今天我写一个类似于百度知道那样有提问答案的页面,所有的数据都是页面第一次加载时通过ajax得到的
希望实现的效果是提问者可以通过店家每个答案后面的星星符号选择采纳此答案,被采纳的答案星星图标会变成全黑的。
开始我是这样写的
复制代码 代码如下:
$('.choose_right_answer').bind('click',function(){
if(currentUser==questioner) {
if ($(this).attr("src") == "img/star_fav_empty.png")
$(this).attr("src", "img/star_fav.png");
else
$(this).attr("src", "img/star_fav_empty.png");
}
});
.choose_right_answer是每个星星class名
运行之后点击星星没有反应
于是我在上面所示代码段之前加上了一个alert("test")
此时加载页面后弹出对话框test之后,星星图标上绑定的事件可以正常执行。
上网搜了一通答案,得到的结果是由于所有的这些答案的节点都是动态生成的,因此可能在这些节点还没有执行完时,就执行了事件绑定,以至于并没有真正将事件绑定到生成的这些答案的节点。
而加上alert之后,可以明显看到,alert语句在所有数据得到后才执行,确保了事件绑定在数据加载完之后执行,因此事件成功绑定到了各个回答上。
http://img.blog.csdn.net/20140531202827265
解决方法,使用jQuery中的on来绑定事件
复制代码 代码如下:
$("#answer_wrap").on('click','.choose_right_answer',function(){
if(currentUser==questioner) {
if ($(this).attr("src") == "img/star_fav_empty.png")
$(this).attr("src", "img/star_fav.png");
else
$(this).attr("src", "img/star_fav_empty.png");
}
});
answer_wrap是所有回答所在块的id
所有在这个块里class为choose_right_answer的元素如果发生点击则事件冒泡到answer_wrap,执行对应函数,其余在这个块中的元素发生点击事件则忽略
这样就可以解决动态加载数据中事件绑定的问题
您可能感兴趣的文章:
- JQuery实现当鼠标停留在某区域3秒后自动执行
- JQuery给元素绑定click事件多次执行的解决方法
- jquery阻止后续事件只执行第一个事件
- jquery $.ajax各个事件执行顺序
- jquery 事件执行检测代码
- JQuery 给元素绑定click事件多次执行的解决方法
- 浅析jquery如何判断滚动条滚到页面底部并执行事件
- Jquery on方法绑定事件后执行多次的解决方法
- JQuery中DOM加载与事件执行实例分析
- 浅谈js在html中的加载执行顺序,多个jquery ready执行顺序
- 使用jQuery加载html页面到指定的div实现方法
- Jquery在指定DIV加载HTML示例代码
- jQuery实现在HTML文档加载完毕后自动执行某个事件的方法