jQuery中不为人知的秘密之三——判断元素上是否绑定了事件

好久没写博客了,抱歉抱歉,最近半年很忙很忙。
正好群里 Q.Lee.lulu 问起怎样判断有没有绑定一个事件。
我研究了一下之后发现,jQuery都将事件缓存起来了,其实也是为了防止内存溢出以及页面unload的时候的速度,也包括多函数触发,方便管理等诸多好处,具体可以参考此文
jQuery会在window.unload的时候卸载所有绑定过的事件,释放内存的。

OK,言归正传。判断元素上是否绑定过事件用如下语句


jQuery.data(elem,”events”)[type] //老版本也能用
$(elem).data(“events”)[type] //1.2.3以后才能用

返回值:
一个Object,可以用for in来遍历。或者undefined。
参数:
elem是一个DOM对象,type是事件类型。
举例:
判断id为foo的元素上是否绑定了click事件

if( $(“#foo”).data(“events”)[“click”] ){
//your code
}

《jQuery中不为人知的秘密之三——判断元素上是否绑定了事件》有7个想法

  1. 天啊,这种方法我可从来没有用过啊,以前一直都不管有没有绑定的,或者如果绑定了来个alert()测试下,呵呵,现在有好办法了,

    谢谢。

  2. 哎,貌似要这样才行
    var tempE = $(“#foo”).data(“events”);
    if(tempE){
    if(tempE[“click”] ){
    //your code
    }
    }

发表评论