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语句在所有数据得到后才执行,确保了事件绑定在数据加载完之后执行,因此事件成功绑定到了各个回答上。




解决方法,使用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,执行对应函数,其余在这个块中的元素发生点击事件则忽略

这样就可以解决动态加载数据中事件绑定的问题



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值