Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
Provide a way to simulate default browser actions. Fixes #5973.
  • Loading branch information
jeresig committed Jan 28, 2010
1 parent 31f1e99 commit 0252b78
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 3 deletions.
7 changes: 5 additions & 2 deletions src/event.js
Expand Up @@ -333,9 +333,12 @@ jQuery.event = {

} else if ( !event.isDefaultPrevented() ) {
var target = event.target, old,
isClick = jQuery.nodeName(target, "a") && type === "click";
isClick = jQuery.nodeName(target, "a") && type === "click",
special = jQuery.event.special[ type ] || {};

if ( (!special._default || special._default.call( elem, event ) === false) &&
!isClick && !(target && target.nodeName && jQuery.noData[target.nodeName.toLowerCase()]) ) {

if ( !isClick && !(target && target.nodeName && jQuery.noData[target.nodeName.toLowerCase()]) ) {
try {
if ( target[ type ] ) {
// Make sure that we don't accidentally re-trigger the onFOO events
Expand Down
7 changes: 6 additions & 1 deletion test/unit/event.js
Expand Up @@ -72,7 +72,7 @@ test("bind(), multiple events at once and namespaces", function() {
});

test("bind(), namespace with special add", function() {
expect(9);
expect(18);

var div = jQuery("<div/>").bind("test", function(e) {
ok( true, "Test event fired." );
Expand All @@ -81,6 +81,11 @@ test("bind(), namespace with special add", function() {
var i = 0;

jQuery.event.special.test = {
_default: function(e) {
equals( this, document, "Make sure we're at the top of the chain." );
equals( e.type, "test", "And that we're still dealing with a test event." );
equals( e.target, div[0], "And that the target is correct." );
},
setup: function(){},
teardown: function(){},
add: function( handler, data, namespaces ) {
Expand Down

0 comments on commit 0252b78

Please sign in to comment.