aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/event.js26
1 files changed, 13 insertions, 13 deletions
diff --git a/src/event.js b/src/event.js
index e4bc153f1..f53f67191 100644
--- a/src/event.js
+++ b/src/event.js
@@ -359,7 +359,7 @@ jQuery.event = {
return;
}
- // Determine handlers that should run if there are delegated events
+ // Determine handlers
handlerQueue = jQuery.event.handlers.call( this, event, handlers );
// Run delegates first; they may want to stop propagation beneath us
@@ -399,30 +399,30 @@ jQuery.event = {
},
handlers: function( event, handlers ) {
- var i, cur, selMatch, matches, handleObj, sel,
+ var i, matches, sel, handleObj,
handlerQueue = [],
- delegateCount = handlers.delegateCount;
+ delegateCount = handlers.delegateCount,
+ cur = event.target;
+ // Find delegate handlers
// Avoid non-left-click bubbling in Firefox (#3861)
- if ( delegateCount && !(event.button && event.type === "click") ) {
+ if ( delegateCount && (!event.button || event.type !== "click") ) {
- for ( cur = event.target; cur != this; cur = cur.parentNode || this ) {
+ for ( ; cur != this; cur = cur.parentNode || this ) {
- // Don't process clicks (ONLY) on disabled elements (#6911, #8165, #11382, #11764)
+ // Don't process clicks on disabled elements (#6911, #8165, #11382, #11764)
if ( cur.disabled !== true || event.type !== "click" ) {
- selMatch = {};
matches = [];
- i = 0;
- for ( ; i < delegateCount; i++ ) {
+ for ( i = 0; i < delegateCount; i++ ) {
handleObj = handlers[ i ];
sel = handleObj.selector;
- if ( selMatch[ sel ] === undefined ) {
- selMatch[ sel ] = handleObj.needsContext ?
+ if ( matches[ sel ] === undefined ) {
+ matches[ sel ] = handleObj.needsContext ?
jQuery( sel, this ).index( cur ) >= 0 :
jQuery.find( sel, this, null, [ cur ] ).length;
}
- if ( selMatch[ sel ] ) {
+ if ( matches[ sel ] ) {
matches.push( handleObj );
}
}
@@ -434,7 +434,7 @@ jQuery.event = {
}
// Add the remaining (directly-bound) handlers
- if ( handlers.length > delegateCount ) {
+ if ( delegateCount < handlers.length ) {
handlerQueue.push({ elem: this, handlers: handlers.slice( delegateCount ) });
}