微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

jQuery on()方法绑定动态元素的点击事件无响应的解决办法

<div class="jb51code">
<pre class="brush:js;">
$('#check_all').on('click',function(){
alert(1);
});
$("#yujinlist").append(html);
count++;
}

以上代码执行时,点击#check_all时,alert一直没反应,后在网上查资料时,才知道on前面的元素也必须在页面加载的时候就存在于dom里面,那原话是这样的:

支持给动态元素和属性绑定事件的是live和on,其中live在JQUERY 1.7之后就不推荐使用了。现在主要用on,使用on的时候也要注意,on前面的元素也必须在页面加载的时候就存在于dom里面。动态的元素或者样式等,可以放在on的第二个参数里面。

因为我先输出相关html,再执行就没问题了。

rush:js;">
\
Box col-xs-1">\ \
\
Box col-xs-1 ">\ \
\
Box col-xs-1 ">\ \
\
Box col-xs-1">\ \
\
Box col-xs-1">\ \
\
Box col-xs-1">\ \
\
Box col-xs-1">\ \
\
Box col-xs-1">\ \
\
\
\
\
\
\
'; $('#check_all').on('click',function(){ var that = this; $('#check_item').find('input:checkBox') .each(function(){ alert(2); this.checked = that.checked; $(this).closest('.col-xs-1').toggleClass('selected'); }); });

下面看下jquery on() 方法绑定动态元素

jQuery on()方法是官方推荐的绑定事件的一个方法。使用 on() 方法可以给将来动态创建的动态元素绑定指定的事件,例如append等。

rush:js;">

错误用法,下面方法只为第一个class 为 evt 的div 绑定了click事件,使用append动态创建的div则没有绑定

rush:js;">

正确的用法如下:

rush:js;">

以上所述是小编给大家介绍的jQuery on()方法绑定动态元素的点击事件无响应的解决办法。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

jquery绑定动态元素

相关推荐