unbind()方法能够移除所有的或被选的事件处理程序,或者当事件发生时终止指定函数的运行。
该方法也可以通过 event 对象取消绑定的事件处理程序。该方法也用于对自身内部的事件取消绑定(比如当事件已被触发一定次数之后,删除事件处理程序)。
注意:如果未规定参数,则 unbind() 方法会删除指定元素的所有事件处理程序。
注意:unbind() 方法适用于任意由 jQuery 添加的事件处理程序。
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(事件类型,事件处理函数名称)
更多前端开发知识,请查阅 HTML中文网 !!
以上就是jQuery unbind()方法怎么使用?的详细内容,更多请关注易知道|edz.cc其它相关文章!