aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDave Methvin <dave.methvin@gmail.com>2011-10-23 22:25:13 -0400
committerDave Methvin <dave.methvin@gmail.com>2011-10-24 11:18:18 -0400
commit4ac6f8d9d322c7e468ed0d58e402abe7bdca354d (patch)
tree6c93204fd084fdb68b52a14bc9b876c8e6b1796c
parentb208042f520b2ee768a93323d6bdc65eabfb0d65 (diff)
downloadjquery-4ac6f8d9d322c7e468ed0d58e402abe7bdca354d.tar.gz
jquery-4ac6f8d9d322c7e468ed0d58e402abe7bdca354d.zip
Make jQuery().off(event) work for delegated events.
Logic to handle detaching by event was in both .off() and jQuery.event.remove; now it's only in .off(). It's a bit of a strange case since the event object (not the jQuery set) specifies the element.
-rw-r--r--src/event.js22
-rw-r--r--test/unit/event.js14
2 files changed, 25 insertions, 11 deletions
diff --git a/src/event.js b/src/event.js
index 42d30e9aa..64cfda530 100644
--- a/src/event.js
+++ b/src/event.js
@@ -166,13 +166,6 @@ jQuery.event = {
return;
}
- // For removal, types can be an Event object
- if ( types && types.type && types.handler ) {
- handler = types.handler;
- types = types.type;
- selector = types.selector;
- }
-
// Once for each type.namespace in types; type may be omitted
types = (types || "").replace( rhoverHack, "mouseover$1 mouseout$1" ).split(" ");
for ( t = 0; t < types.length; t++ ) {
@@ -919,7 +912,8 @@ jQuery.fn.extend({
if ( one === 1 ) {
origFn = fn;
fn = function( event ) {
- jQuery.event.remove( event.currentTarget || this, event );
+ // Can use an empty set, since event contains the info
+ jQuery().off( event );
return origFn.apply( this, arguments );
};
// Use same guid so caller can remove using origFn
@@ -933,9 +927,15 @@ jQuery.fn.extend({
return this.on.call( this, types, selector, data, fn, 1 );
},
off: function( types, selector, fn ) {
- if ( types && types.preventDefault ) {
- // ( event ) native or jQuery.Event
- return this.off( types.type, types.handler, types.selector );
+ if ( types && types.preventDefault && types.handleObj ) {
+ // ( event ) dispatched jQuery.Event
+ var handleObj = types.handleObj;
+ jQuery( types.currentTarget ).off(
+ handleObj.namespace? handleObj.type + "." + handleObj.namespace : handleObj.type,
+ handleObj.selector,
+ handleObj.handler
+ );
+ return this;
}
if ( typeof types === "object" ) {
// ( types-object [, selector] )
diff --git a/test/unit/event.js b/test/unit/event.js
index 905e6ab99..bb622f577 100644
--- a/test/unit/event.js
+++ b/test/unit/event.js
@@ -2054,6 +2054,20 @@ test(".delegate()/.undelegate()", function() {
jQuery("#body").undelegate("#nothiddendiv div", "click");
});
+test("jQuery.off using dispatched jQuery.Event", function() {
+ expect(1);
+
+ var markup = jQuery( '<p><a href="#">target</a></p>' ),
+ count = 0;
+ markup
+ .on( "click.name", "a", function( event ) {
+ equals( ++count, 1, "event called once before removal" );
+ jQuery().off( event );
+ })
+ .find( "a" ).click().click().end()
+ .remove();
+});
+
test("stopPropagation() stops directly-bound events on delegated target", function() {
expect(1);