Fixed #2027 - make sure that cloned elements (within appendTo, etc.) have their events cloned by default.

This commit is contained in:
John Resig 2007-12-20 13:36:56 +00:00
parent b740fe5632
commit 3261544c38
2 changed files with 7 additions and 2 deletions

View file

@ -498,7 +498,7 @@ jQuery.fn = jQuery.prototype = {
jQuery.each(elems, function(){
var elem = clone ?
this.cloneNode( true ) :
jQuery( this ).clone( true )[0] :
this;
// execute all scripts after the elements have been injected

View file

@ -1,7 +1,7 @@
module("event");
test("bind()", function() {
expect(18);
expect(19);
var handler = function(event) {
ok( event.data, "bind() with data, check passed data exists" );
@ -85,6 +85,11 @@ test("bind()", function() {
$("#nonnodes").contents().bind("tester", function () {
equals(this.nodeType, 1, "Check node,textnode,comment bind just does real nodes" );
}).trigger("tester");
// Make sure events stick with appendTo'd elements (which are cloned) #2027
$("<a href='#fail' class='test'>test</a>").click(function(){ return false; }).appendTo("p");
ok( $("a.test:first").triggerHandler("click") === false, "Handler is bound to appendTo'd elements" );
reset();
});
test("click()", function() {