aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDave Methvin <dave.methvin@gmail.com>2012-08-28 10:07:16 -0400
committerDave Methvin <dave.methvin@gmail.com>2012-08-28 10:07:16 -0400
commitafd717df9e189d3e374ce938f03e2712f31c29e3 (patch)
tree9f36ebee37cc7e1354e3af7da83529281f635d37
parentc078b83b3fea891e0c228a9f2d101481678b4c9d (diff)
downloadjquery-afd717df9e189d3e374ce938f03e2712f31c29e3.tar.gz
jquery-afd717df9e189d3e374ce938f03e2712f31c29e3.zip
Fix #12383. All selectors should be delegateTarget-relative
-rw-r--r--src/event.js9
-rw-r--r--test/unit/event.js24
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() {