手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >jQuery绑定事件不执行但alert后可以正常执行
jQuery绑定事件不执行但alert后可以正常执行
摘要:因为我不知道怎么描述这个问题,故标题起的这么坑爹主要过程是这样的,今天我写一个类似于百度知道那样有提问答案的页面,所有的数据都是页面第一次加...

因为我不知道怎么描述这个问题,故标题起的这么坑爹

主要过程是这样的,今天我写一个类似于百度知道那样有提问答案的页面,所有的数据都是页面第一次加载时通过ajax得到的

1

希望实现的效果是提问者可以通过店家每个答案后面的星星符号选择采纳此答案,被采纳的答案星星图标会变成全黑的。

开始我是这样写的

复制代码 代码如下:

$('.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绑定事件不执行但alert后可以正常执行】相关文章:

JQuery中DOM事件合成用法实例分析

jQuery基于图层模仿五星星评价功能的方法

jQuery常用知识点总结以及平时封装常用函数

javascript相关事件的几个概念

jquery插件validation实现验证身份证号等

jQuery实现鼠标经过图片变亮其他变暗效果

jQuery插件expander实现图片翻转特效

jQuery插件pagewalkthrough实现引导页效果

jQuery使用zTree插件实现树形菜单和异步加载

jquery中添加属性和删除属性

精品推荐
分类导航