remove: function( elem, types, handler, selector ) {
var elemData = jQuery.hasData( elem ) && jQuery._data( elem ),
- t, tns, type, namespaces, origCount,
+ t, tns, type, origType, namespaces, origCount,
j, events, special, handle, eventType, handleObj;
if ( !elemData || !(events = elemData.events) ) {
types = jQuery.trim( hoverHack( types || "" ) ).split(" ");
for ( t = 0; t < types.length; t++ ) {
tns = rtypenamespace.exec( types[t] ) || [];
- type = tns[1];
+ type = origType = tns[1];
namespaces = tns[2];
// Unbind all events (on this namespace, if provided) for the element
namespaces = namespaces ? new RegExp("(^|\\.)" + namespaces.split(".").sort().join("\\.(?:.*\\.)?") + "(\\.|$)") : null;
// Only need to loop for special events or selective removal
- if ( handler || namespaces || selector || special.remove ) {
+ if ( handler || namespaces || selector || special.remove || origType !== type ) {
for ( j = 0; j < eventType.length; j++ ) {
handleObj = eventType[ j ];
- if ( !handler || handler.guid === handleObj.guid ) {
- if ( !namespaces || namespaces.test( handleObj.namespace ) ) {
- if ( !selector || selector === handleObj.selector || selector === "**" && handleObj.selector ) {
- eventType.splice( j--, 1 );
-
- if ( handleObj.selector ) {
- eventType.delegateCount--;
- }
- if ( special.remove ) {
- special.remove.call( elem, handleObj );
- }
- }
+ if ( origType === handleObj.origType &&
+ ( !handler || handler.guid === handleObj.guid ) &&
+ ( !namespaces || namespaces.test( handleObj.namespace ) ) &&
+ ( !selector || selector === handleObj.selector || selector === "**" && handleObj.selector ) ) {
+ eventType.splice( j--, 1 );
+
+ if ( handleObj.selector ) {
+ eventType.delegateCount--;
+ }
+ if ( special.remove ) {
+ special.remove.call( elem, handleObj );
}
}
}
ok( true, "click fired on div" );
})
.find( "p" )
- .on( "click", function() {
+ .on( "click", function() {
ok( true, "click fired on p" );
})
.click()
test("jQuery.Event.currentTarget", function(){
expect(2);
-
+
jQuery('<div><p><button>shiny</button></p></div>')
.on( "click", "p", function( e ){
equal( e.currentTarget, this, "Check delegated currentTarget on event" );
test("jQuery.off using dispatched jQuery.Event", function() {
expect(1);
-
+
var markup = jQuery( '<p><a href="#">target</a></p>' ),
count = 0;
markup
test("stopPropagation() stops directly-bound events on delegated target", function() {
expect(1);
-
+
var markup = jQuery( '<div><p><a href="#">target</a></p></div>' );
markup
.on( "click", function() {
test("inline handler returning false stops default", function() {
expect(1);
-
+
var markup = jQuery('<div><a href="#" onclick="return false">x</a></div>');
markup.click(function(e) {
ok( e.isDefaultPrevented(), "inline handler prevented default");
jQuery("#onandoff").remove();
});
+test("special bind/delegate name mapping", function() {
+ expect( 7 );
+
+ jQuery.event.special.slap = {
+ bindType: "click",
+ delegateType: "swing",
+ handle: function( event ) {
+ equal( event.handleObj.origType, "slap", "event type is correct for " + event.type );
+ equal( event.target.id, "mammy", "slapped your mammy" );
+ }
+ };
+
+ var comeback = function( event ) {
+ ok( true, "event " + event.type + " triggered" );
+ };
+
+ jQuery( '<div><button id="mammy">Are We Not Men?</button></div>' )
+ .on( "slap", "button", jQuery.noop )
+ .on( "swing", "button", comeback )
+ .find( "button" )
+ .on( "slap", jQuery.noop )
+ .on( "click", comeback )
+ .trigger( "click" ) // bindType-slap and click
+ .off( "slap" )
+ .trigger( "click" ) // click
+ .off( "click" )
+ .trigger( "swing" ) // delegateType-slap and swing
+ .end()
+ .off( "slap swing" )
+ .find( "button " ) // everything should be gone
+ .trigger( "slap" )
+ .trigger( "click" )
+ .trigger( "swing" )
+ .end();
+});
test(".on and .off, selective mixed removal (#10705)", function() {
expect(7);
var clockout = 0,
- timingx = function( e ) {
+ timingx = function( e ) {
ok( true, "triggered " + e.type );
};
-
+
jQuery( '<p>Strange Pursuit</p>' )
.on( "click", timingx )
.on( "click.duty", timingx )