mirror of
https://github.com/jquery/jquery.git
synced 2025-01-10 18:24:24 +00:00
No need to do the closest match if no selectors are passed in.
This commit is contained in:
parent
e534a310c7
commit
4daae7a79f
49
src/event.js
49
src/event.js
@ -749,13 +749,30 @@ jQuery.fn.extend({
|
|||||||
});
|
});
|
||||||
|
|
||||||
function liveHandler( event ) {
|
function liveHandler( event ) {
|
||||||
var stop = true, elems = [], args = arguments;
|
var stop = true, elems = [], selectors = [], args = arguments,
|
||||||
|
related, match, fn, elem, j, i,
|
||||||
|
live = jQuery.extend({}, jQuery.data( this, "events" ).live);
|
||||||
|
|
||||||
jQuery.each( jQuery.data( this, "events" ).live || [], function( i, fn ) {
|
for ( j in live ) {
|
||||||
if ( fn.live === event.type ) {
|
if ( live[j].live === event.type ) {
|
||||||
var elem = jQuery( event.target ).closest( fn.selector, event.currentTarget )[0],
|
selectors.push( live[j].selector );
|
||||||
related;
|
}
|
||||||
if ( elem ) {
|
}
|
||||||
|
|
||||||
|
console.log( event.type, selectors+"" );
|
||||||
|
|
||||||
|
// TODO: Make sure that duplicate selectors aren't run
|
||||||
|
match = jQuery( event.target ).closest( selectors, event.currentTarget );
|
||||||
|
|
||||||
|
console.log( "match", match, selectors+"" );
|
||||||
|
|
||||||
|
for ( i = 0, l = match.length; i < l; i++ ) {
|
||||||
|
for ( j in live ) {
|
||||||
|
fn = live[j];
|
||||||
|
elem = match[i].elem;
|
||||||
|
related = null;
|
||||||
|
|
||||||
|
if ( match[i].selector === fn.selector) {
|
||||||
// Those two events require additional checking
|
// Those two events require additional checking
|
||||||
if ( fn.live === "mouseenter" || fn.live === "mouseleave" ) {
|
if ( fn.live === "mouseenter" || fn.live === "mouseleave" ) {
|
||||||
related = jQuery( event.relatedTarget ).closest( fn.selector )[0];
|
related = jQuery( event.relatedTarget ).closest( fn.selector )[0];
|
||||||
@ -766,19 +783,19 @@ function liveHandler( event ) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
}
|
||||||
|
|
||||||
elems.sort(function( a, b ) {
|
console.log( "elems", elems );
|
||||||
return a.closer - b.closer;
|
|
||||||
});
|
|
||||||
|
|
||||||
jQuery.each(elems, function() {
|
for ( i = 0, l = elems.length; i < l; i++ ) {
|
||||||
event.currentTarget = this.elem;
|
match = elems[i];
|
||||||
event.data = this.fn.data;
|
event.currentTarget = match.elem;
|
||||||
if ( this.fn.apply( this.elem, args ) === false ) {
|
event.data = match.fn.data;
|
||||||
return (stop = false);
|
if ( match.fn.apply( match.elem, args ) === false ) {
|
||||||
|
stop = false;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
});
|
}
|
||||||
|
|
||||||
return stop;
|
return stop;
|
||||||
}
|
}
|
||||||
|
@ -58,7 +58,7 @@ jQuery.fn.extend({
|
|||||||
if ( jQuery.isArray( selectors ) ) {
|
if ( jQuery.isArray( selectors ) ) {
|
||||||
var ret = [], cur = this[0], selector;
|
var ret = [], cur = this[0], selector;
|
||||||
|
|
||||||
if ( cur ) {
|
if ( cur && selectors.length ) {
|
||||||
for ( var i = 0, l = selectors.length; i < l; i++ ) {
|
for ( var i = 0, l = selectors.length; i < l; i++ ) {
|
||||||
selectors[i] = jQuery.expr.match.POS.test( selector ) ?
|
selectors[i] = jQuery.expr.match.POS.test( selector ) ?
|
||||||
jQuery( selector, context || this.context ) :
|
jQuery( selector, context || this.context ) :
|
||||||
|
Loading…
Reference in New Issue
Block a user