diff options
author | Dave Methvin <dave.methvin@gmail.com> | 2012-08-28 10:07:16 -0400 |
---|---|---|
committer | Dave Methvin <dave.methvin@gmail.com> | 2012-08-28 10:07:16 -0400 |
commit | afd717df9e189d3e374ce938f03e2712f31c29e3 (patch) | |
tree | 9f36ebee37cc7e1354e3af7da83529281f635d37 | |
parent | c078b83b3fea891e0c228a9f2d101481678b4c9d (diff) | |
download | jquery-afd717df9e189d3e374ce938f03e2712f31c29e3.tar.gz jquery-afd717df9e189d3e374ce938f03e2712f31c29e3.zip |
Fix #12383. All selectors should be delegateTarget-relative
-rw-r--r-- | src/event.js | 9 | ||||
-rw-r--r-- | test/unit/event.js | 24 |
2 files changed, 23 insertions, 10 deletions
diff --git a/src/event.js b/src/event.js index c22f5f872..0c7d827dc 100644 --- a/src/event.js +++ b/src/event.js @@ -361,7 +361,7 @@ jQuery.event = { // Make a writable jQuery.Event from the native event object event = jQuery.event.fix( event || window.event ); - var i, j, cur, jqcur, ret, selMatch, matched, matches, handleObj, sel, related, + var i, j, cur, ret, selMatch, matched, matches, handleObj, sel, related, handlers = ( (jQuery._data( this, "events" ) || {} )[ event.type ] || []), delegateCount = handlers.delegateCount, args = [].slice.call( arguments ), @@ -382,23 +382,18 @@ jQuery.event = { // Avoid non-left-click bubbling in Firefox (#3861) if ( delegateCount && !(event.button && event.type === "click") ) { - // Pregenerate a single jQuery object for reuse with .is() - jqcur = jQuery(this); - jqcur.context = this; - for ( cur = event.target; cur != this; cur = cur.parentNode || this ) { // Don't process clicks (ONLY) on disabled elements (#6911, #8165, #xxxx) if ( cur.disabled !== true || event.type !== "click" ) { selMatch = {}; matches = []; - jqcur[0] = cur; for ( i = 0; i < delegateCount; i++ ) { handleObj = handlers[ i ]; sel = handleObj.selector; if ( selMatch[ sel ] === undefined ) { - selMatch[ sel ] = jqcur.is( sel ); + selMatch[ sel ] = jQuery( sel, this ).index( cur ) >= 0; } if ( selMatch[ sel ] ) { matches.push( handleObj ); diff --git a/test/unit/event.js b/test/unit/event.js index 74cf1b9b7..5f609247a 100644 --- a/test/unit/event.js +++ b/test/unit/event.js @@ -2343,9 +2343,10 @@ test("jQuery.off using dispatched jQuery.Event", function() { }); test( "delegated event with delegateTarget-relative selector", function() { - expect(2); - var markup = jQuery("<ul><li><a id=\"a0\"></a><ul id=\"ul0\"><li><a id=\"a0_0\"></a></li><li><a id=\"a0_1\"></a></li></ul></li></ul>").appendTo("#qunit-fixture"); + expect(3); + var markup = jQuery("<ul><li><a id=\"a0\"></a><ul id=\"ul0\"><li class=test><a id=\"a0_0\"></a></li><li><a id=\"a0_1\"></a></li></ul></li></ul>").appendTo("#qunit-fixture"); + // Positional selector (#11315) markup .on( "click", ">li>a", function() { ok( this.id === "a0", "child li was clicked" ); @@ -2356,7 +2357,24 @@ test( "delegated event with delegateTarget-relative selector", function() { }) .end() .find("a").click().end() - .remove(); + .find("#ul0").off(); + + // Non-positional selector (#12383) + markup = markup.wrap("<div />").parent(); + markup + .find("#ul0") + .on( "click", "div li a", function() { + ok( false, "div is ABOVE the delegation point!" ); + }) + .on( "click", "ul a", function() { + ok( false, "ul is the delegation point!" ); + }) + .on( "click", "li.test a", function() { + ok( true, "li.test is below the delegation point." ); + }) + .find("#a0_0").click(); + + markup.remove(); }); test("stopPropagation() stops directly-bound events on delegated target", function() { |