Make sure that events are cloned for wrap, fixes #2977.
This commit is contained in:
parent
77510fec02
commit
f5b649fafb
|
@ -48,7 +48,7 @@ jQuery.fn.extend({
|
||||||
|
|
||||||
if ( this[0] ) {
|
if ( this[0] ) {
|
||||||
// The elements to wrap the target around
|
// The elements to wrap the target around
|
||||||
var wrap = jQuery( html, this[0].ownerDocument ).eq(0).clone();
|
var wrap = jQuery( html, this[0].ownerDocument ).eq(0).clone(true);
|
||||||
|
|
||||||
if ( this[0].parentNode ) {
|
if ( this[0].parentNode ) {
|
||||||
wrap.insertBefore( this[0] );
|
wrap.insertBefore( this[0] );
|
||||||
|
|
|
@ -13,7 +13,7 @@ test("text()", function() {
|
||||||
});
|
});
|
||||||
|
|
||||||
var testWrap = function(val) {
|
var testWrap = function(val) {
|
||||||
expect(15);
|
expect(18);
|
||||||
var defaultText = 'Try them out:'
|
var defaultText = 'Try them out:'
|
||||||
var result = jQuery('#first').wrap(val( '<div class="red"><span></span></div>' )).text();
|
var result = jQuery('#first').wrap(val( '<div class="red"><span></span></div>' )).text();
|
||||||
equals( defaultText, result, 'Check for wrapping of on-the-fly html' );
|
equals( defaultText, result, 'Check for wrapping of on-the-fly html' );
|
||||||
|
@ -54,6 +54,20 @@ var testWrap = function(val) {
|
||||||
equals( j[0].parentNode.parentNode.childNodes.length, 1, "There should only be one element wrapping." );
|
equals( j[0].parentNode.parentNode.childNodes.length, 1, "There should only be one element wrapping." );
|
||||||
equals( j.length, 1, "There should only be one element (no cloning)." );
|
equals( j.length, 1, "There should only be one element (no cloning)." );
|
||||||
equals( j[0].parentNode.nodeName.toUpperCase(), "P", "The span should be in the paragraph." );
|
equals( j[0].parentNode.nodeName.toUpperCase(), "P", "The span should be in the paragraph." );
|
||||||
|
|
||||||
|
// Wrap an element with a jQuery set
|
||||||
|
j = jQuery("<span/>").wrap(jQuery("<div></div>"));
|
||||||
|
equals( j[0].parentNode.nodeName.toLowerCase(), "div", "Wrapping works." );
|
||||||
|
|
||||||
|
// Wrap an element with a jQuery set and event
|
||||||
|
result = jQuery("<div></div>").click(function(){
|
||||||
|
ok(true, "Event triggered.");
|
||||||
|
});
|
||||||
|
|
||||||
|
j = jQuery("<span/>").wrap(result);
|
||||||
|
equals( j[0].parentNode.nodeName.toLowerCase(), "div", "Wrapping works." );
|
||||||
|
|
||||||
|
j.parent().trigger("click");
|
||||||
}
|
}
|
||||||
|
|
||||||
test("wrap(String|Element)", function() {
|
test("wrap(String|Element)", function() {
|
||||||
|
|
Loading…
Reference in a new issue