jquery中关于事件绑定的问题

jquery中的事件绑定方法:

1.将事件绑定到document上,当整个dom中发生点击事件时会先判断当前点击的对象是否匹配该className,再执行点击的回调方法。适用于多组重复元素的点击事件。

$(document).on('click','.className',function(){});
2.将事件绑定到该 className的元素上,一旦该元素发生点击事件立即执行回调方法。如果是单独的元素点击事件,用此种绑定方法更为高效。缺点是只在页面加载的时候绑定一次,无法获取后加载在页面上的元素。

$('.className').on('click',function(){});

举例:

导航栏的切换动作

$(document).on("click","ul li",function(){
      $(this).addClass("changeBgColor").siblings().removeClass("changeBgColor")
    });
由于导航菜单(li)并不是写死在页面上,而是由数据库读取,并循环显示在页面上,此时用第二种绑定方法无法获取“li”,因此要用第一种绑定方式,且此时不需要判断是哪一个”li“发生了点击事件,因为$(ducoment).on()方法会自动判断是哪一个。

注:若”li“元素是写死在页面上的,则可以使用第二种绑定方式,这里需要用$(this).index()方法来判断是哪一个li发生点击事件,而上面一种方法则不需要手动进行判断。如下:

$(‘ul li’).on(“click”,function(){
$(‘ul li’).eq($(this).index()).addClass(“changeBgColor”).siblings().removeClass(“changeBgColor”)
});

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值