1、jquery事件绑定和委托的实现

本文详细介绍了jQuery中事件绑定和委托的多种方法,包括on()、bind()、live()、delegate(),并提供了使用示例和注意事项,旨在帮助开发者高效地在网页中添加交互功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

jQuery的事件绑定和委托可以使用 on()、one()、bind()、live()、delegate()等方法实现。

1、on()  :

语法:$(selector).on(event,childSelector,data,function)

作用:可以在被选元素及子元素上添加一个或多个事件处理程序,并且此事件处理程序适用于当前及未来的元素。

一般使用:

    $("#thisA").on("click", function(){ 

            console.log("id是thisA的标签添加了click点击事件。");

    }); 

或:

     $("#thisA").on("click mouseover",{id:"id"}, function(e){ 

            console.log("id是thisA的标签添加了点击和鼠标悬停事件,传递的值是:"+e.data.id);

    });  

或:

    $("body").on("click","#thisA" ,function(){

            console.log("可以给当前元素下的子元素添加事件");

    });

可用off()方法移除事件绑定:

    $("#thisA").off("click");

如需添加只运行一次的事件然后移除,可直接使用 one() 。

 

2、bind():

语法:$(selector).bind(event,data,function,map)

作用:向被选元素添加一个或多个事件处理程序,以及当事件发生时运行的函数,不能为未来元素添加事件。

一般使用:

     $("#thisA").bind("click", function(){ 

        console.log("id是thisA的标签添加了click点击事件。");

      });

或:

      $("button").bind({

        click:function(){$("p").slideToggle();},

        mouseover:function(){$("body").css("background-color","#E9E9E4");}, 

        mouseout:function(){$("body").css("background-color","#FFFFFF");} 

 

      }); 

 

可用unbind()方法移除事件绑定。 

 

 

3、live() :

    此方法在 jQuery 版本 1.7 中废弃,在版本 1.9 中被移除。请使用 on() 方法代替。

4、delegate():

语法:$(selector).delegate(childSelector,event,data,function)

用法:为指定的元素及其子元素添加一个或多个事件处理程序,此方法适用于当前或未来的元素。

一般使用:使用实例类似于on()。

 

可用undelegate()方法移除事件绑定。

 

 

总结:jQuery的事件绑定和委托基本可以使用清一色的on方法进行实现,特殊情况另外考虑。(一家之言,可能有误)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值