jQuery:unbind方法的使用详解

jQuery:unbind方法的使用详解

一、概述:unbind方法只能解绑用jQuery的bind方法以及用jQuery方法注册的事件处理程序。比如:$(‘a’).click(function(){})可以通过unbind解绑。用原生addEventListener以及IE下的attachEvent注册的事件以及使用onclick/onmouseover属性绑定的事件不能通过unbind进行解绑。
例如:

以下的事件可以通过unbind解绑:
$('a').click(function(){});
$('a').bind('click',function(){})

以下的事件不可以通过unbind解绑
var a = document.getElementById('a');
a.addEventListener(a,function(){},false);
a.onclick = function(){}

二、使用方式:

  • 传入一个或者多个事件名称字符串,可以解绑该元素上指定的处理事件。
    例如:
  •     //解绑所有a上的click事件
        $('a').unbind('click');
        //解绑a上的所有mouseover以及mouseoverout事件
        $('a').unbind('mouseover mouseout');

  • 以上方式比较粗暴,如果在多模块开发中,可能会直接把别的模块注册的处理函数给解绑了。所以可以采用命名空间的方式进行解绑。例如:
  •     $('a').unbind('click.myspace')
        $('a').unbind('mouseover.myspace,mouseout.myspace)

  • 使用事件处理程序的引用进行解绑。此时第一个参数是事件名称,第二个参数是事件处理函数名称
  • function handler(){
        alert('hello');
    }
    $('a').bind('click',handler);
    $('a').unbind('click',handler);

  • 传入一个对象给unbind,取消该对象的所有key的名称对应的事件,value是绑定的事件处理函数名称。如下:
  •     $('a').unbind({
            mouseover: mouseoverHandler,
            mouseout: mouseoutHandler
        });

  • 传入一个jQuery Event对象给unbind,也可以解绑该event对应的处理函数。例如:
  •     $('a').click(function(event){
            if(条件满足){
                $('a').unbind(event);
            }
        });

    注意:调用unbind(event)方法就相当于调用unbind(事件类型,事件处理函数名称)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

南窗客斯黄

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值