Fixed problems with removing live events. Fixes #4894.
authorJohn Resig <jeresig@gmail.com>
Wed, 9 Dec 2009 22:43:53 +0000 (14:43 -0800)
committerJohn Resig <jeresig@gmail.com>
Wed, 9 Dec 2009 22:43:53 +0000 (14:43 -0800)
src/event.js
test/unit/event.js

index ac45e7e..e070cb2 100644 (file)
@@ -872,9 +872,7 @@ function liveHandler( event ) {
 }
 
 function liveConvert( type, selector ) {
-       return ["live", type, selector//.replace(/[^\w\s\.]/g, function(ch){ return "\\"+ch})
-                                                                 .replace(/\./g, "`")
-                                                                 .replace(/ /g, "|")].join(".");
+       return ["live", type, selector.replace(/\./g, "`").replace(/ /g, "&")].join(".");
 }
 
 jQuery.each( ("blur focus load resize scroll unload click dblclick " +
index 1ad7c3d..80a2e6a 100644 (file)
@@ -608,7 +608,7 @@ test("toggle(Function, Function, ...)", function() {
 });
 
 test(".live()/.die()", function() {
-       expect(58);
+       expect(61);
 
        var submit = 0, div = 0, livea = 0, liveb = 0;
 
@@ -818,6 +818,43 @@ test(".live()/.die()", function() {
        jQuery('span#liveSpan1 a').click();
        
        jQuery('span#liveSpan1').die('click');
+
+       // Work with deep selectors
+       livee = 0;
+
+       function clickB(){ livee++; }
+
+       jQuery("#nothiddendiv div").live("click", function(){ livee++; });
+       jQuery("#nothiddendiv div").live("click", clickB);
+       jQuery("#nothiddendiv div").live("mouseover", function(){ livee++; });
+
+       equals( livee, 0, "No clicks, deep selector." );
+
+       livee = 0;
+       jQuery("#nothiddendivchild").trigger("click");
+       equals( livee, 2, "Click, deep selector." );
+
+       livee = 0;
+       jQuery("#nothiddendivchild").trigger("mouseover");
+       equals( livee, 1, "Mouseover, deep selector." );
+
+       jQuery("#nothiddendiv div").die("mouseover");
+
+       livee = 0;
+       jQuery("#nothiddendivchild").trigger("click");
+       equals( livee, 2, "Click, deep selector." );
+
+       livee = 0;
+       jQuery("#nothiddendivchild").trigger("mouseover");
+       equals( livee, 0, "Mouseover, deep selector." );
+
+       jQuery("#nothiddendiv div").die("click", clickB);
+
+       livee = 0;
+       jQuery("#nothiddendivchild").trigger("click");
+       equals( livee, 1, "Click, deep selector." );
+
+       jQuery("#nothiddendiv div").die("click");
 });
 
 test("live with change", function(){