jQuery,使用on代替delegate,live 写法区别

27 篇文章 0 订阅
6 篇文章 0 订阅

早期对页面上后期加载的动态元素,赋事件或值的时候,是使用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' );
});

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值