时间:2021-05-26
之前就一直受这个问题的困扰,在jQuery1.7版本之后添加了on方法,之前就了解过,其优越性高于live(),bind(),delegate()等方法,在此之前项目中想用这个来测试结果发现,居然动态生成的标签点击了没反应,而live方法却能够支持,于是乎到处查资料,问网友,结果找了好久在一篇文章中终于找到了答案。。。
jQuery 使用on绑定动态生成的元素时,不能直接用该对象操作,而是选择其非动态生成的父节点然后再找到本身才能达到效果。大家看看源码就知道了。生成的按钮基数项on方法点击无效live方法有效。
比如页面上有下边两个元素:
<input type="button" name="addbtn" value="按钮添加" /><div id="test"></div>使用下边的jQuery代码大家可以对比看看区别:
$(function () {var a = 1,$_div = $('#test');$('input[name=addbtn]').on('click', function () {$_div.append('<input type="button" name="test' + a + '" value="按钮' + a + '"/>');a++;});//偶数项点击事件$_div.on('click', 'input[name^=test]:even', function () { alert('我是有效的on方法,你能看见我吗:' + this.value);});//奇数项绑定的点击事件 发现点击无效,而是用live方法却能够支持$('input[name^=test]:odd').on('click', function () { alert('我是无效的on方法,你不能看见我');});//奇数项绑定的点击事件 发现点击无效,而是用live方法却能够支持$('input[name^=test]:odd').live('click', function () {alert('我是live方法,你能看见我吗:' + this.value);});});以上所述是小编给大家介绍的jQuery on()方法绑定动态元素的点击事件的相关知识,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
如题jQuery使用on()绑定动态生成元素的事件无效的问题jQuery的on()方法可以绑定动态生成元素的事件,但是在实际使用时发现无效。如下HTML:123
本文实例讲述了jQuery给动态添加的元素绑定事件的方法。分享给大家供大家参考。具体分析如下:jquery中绑定事件一般使用bind,或者click,但是这只能
一、问题描述 用jQuery的append()方法动态添加了一段html代码之后,发现在为新添加的元素绑定click事件时无法获取该新元素。二、解决方法 度
本文实例讲述了jQuery支持动态参数将函数绑定到事件上的方法。分享给大家供大家参考。具体分析如下:下面的js代码提供了两种方法用于绑定函数到事件,其中方法二可
下面是jQuery判断元素上是否绑定了指定事件的方法。 例如下面的代码可以判断id=testdiv的元素是否绑定的click事件,这个判断只针对jQuer