早期对页面上后期加载的动态元素,赋事件或值的时候,是使用live的. 由于效率比较低(其实数据不多也感觉不出来),后面使用delegate委托来代替了,再后面,1.7以后使用on 来代替delegate了. live,delegate在新版本中都还可以用. 它们在写法上有差别,一段时间不写容易混,写下来备忘. 如点击div里的任意一个button时增加一个新button:
页面:
|
1
2
3
|
<div id="panel"> <input type="button" name="name" value="clone"class="btnAdd" /></div> |
脚本:
1.1 使用live
jQuery版本1.3+
|
1
2
3
|
$('.btnAdd').live('click', function ()
{ $(this).clone().appendTo('#panel');}); |
1.2 直接把live改成on, 没有给范围比如#panel,这对页面上一开始有的按钮有效. 也就是说无法直接这样代替live
|
1
2
3
|
$('.btnAdd').on('click', function ()
{ $(this).clone().appendTo('#panel');}); |
2.使用delegate 需要给它一个范围才行,如#panel,让它到里面找.这样可以实现live一样的效果.
jQuery版本1.4.3+
|
1
2
3
|
$('#panel').delegate('.btnAdd', 'click', function ()
{ $(this).clone().appendTo('#panel');}); |
3.使用on 给它一个范围才行,如#panel,让它到里面找. 这样可以实现live和delegate一样的效果.
里面的'click', '.btnAdd'跟上面的delegate是相反的.只要记住on click是挨在一起的就行了.
jQuery版本1.7+
|
1
2
3
|
$('#panel').on('click', '.btnAdd', function ()
{ $(this).clone().appendTo('#panel');}); |

本文介绍了在不同jQuery版本中,如何使用live、delegate及on方法为动态生成的元素绑定事件。从1.3版本的live方法开始,逐步过渡到1.4.3版本的delegate,并最终在1.7版本及之后推荐使用on方法。文章通过实例展示了这些方法的具体用法及区别。
376

被折叠的 条评论
为什么被折叠?



