mirror of
https://github.com/jquery/jquery.git
synced 2026-01-24 15:08:25 -05:00
Fixes #11338, .replaceWith should work on detached nodes.
This commit is contained in:
@@ -46,7 +46,7 @@ wrapMap.optgroup = wrapMap.option;
|
||||
wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead;
|
||||
wrapMap.th = wrapMap.td;
|
||||
|
||||
// IE6-8 can't serialize link, script, style, or any html5 (NoScope) tags,
|
||||
// IE6-8 can't serialize link, script, style, or any html5 (NoScope) tags,
|
||||
// unless wrapped in a div with non-breaking characters in front of it.
|
||||
if ( !jQuery.support.htmlSerialize ) {
|
||||
wrapMap._default = [ 1, "X<div>", "</div>" ];
|
||||
@@ -222,7 +222,7 @@ jQuery.fn.extend({
|
||||
}
|
||||
|
||||
// See if we can take a shortcut and just use innerHTML
|
||||
if ( typeof value === "string" && !rnoInnerhtml.test( value ) &&
|
||||
if ( typeof value === "string" && !rnoInnerhtml.test( value ) &&
|
||||
( jQuery.support.htmlSerialize || !rnoshimcache.test( value ) ) &&
|
||||
( jQuery.support.leadingWhitespace || !rleadingWhitespace.test( value ) ) &&
|
||||
!wrapMap[ ( rtagName.exec( value ) || ["", ""] )[1].toLowerCase() ] ) {
|
||||
@@ -252,7 +252,7 @@ jQuery.fn.extend({
|
||||
},
|
||||
|
||||
replaceWith: function( value ) {
|
||||
if ( this[0] && this[0].parentNode ) {
|
||||
if ( this[0] && this[0].parentNode && this[0].parentNode.nodeType != 11 ) {
|
||||
// Make sure that the elements are removed from the DOM before they are inserted
|
||||
// this can help fix replacing a parent with child elements
|
||||
if ( jQuery.isFunction( value ) ) {
|
||||
@@ -278,11 +278,11 @@ jQuery.fn.extend({
|
||||
jQuery(parent).append( value );
|
||||
}
|
||||
});
|
||||
} else {
|
||||
return this.length ?
|
||||
this.pushStack( jQuery(jQuery.isFunction(value) ? value() : value), "replaceWith", value ) :
|
||||
this;
|
||||
}
|
||||
|
||||
return this.length ?
|
||||
this.pushStack( jQuery(jQuery.isFunction(value) ? value() : value), "replaceWith", value ) :
|
||||
this;
|
||||
},
|
||||
|
||||
detach: function( selector ) {
|
||||
|
||||
@@ -915,7 +915,7 @@ test("insertAfter(String|Element|Array<Element>|jQuery)", function() {
|
||||
});
|
||||
|
||||
var testReplaceWith = function(val) {
|
||||
expect(21);
|
||||
expect(22);
|
||||
jQuery("#yahoo").replaceWith(val( "<b id='replace'>buga</b>" ));
|
||||
ok( jQuery("#replace")[0], "Replace element with string" );
|
||||
ok( !jQuery("#yahoo")[0], "Verify that original element is gone, after string" );
|
||||
@@ -976,6 +976,9 @@ var testReplaceWith = function(val) {
|
||||
equal( set[0].nodeName.toLowerCase(), "span", "Replace the disconnected node." );
|
||||
equal( set.length, 1, "Replace the disconnected node." );
|
||||
|
||||
// #11338
|
||||
ok( jQuery("<div>1</div>").replaceWith( val("<span/>") ).is("span"), "#11338, Make sure disconnected node with content is replaced");
|
||||
|
||||
var non_existant = jQuery("#does-not-exist").replaceWith( val("<b>should not throw an error</b>") );
|
||||
equal( non_existant.length, 0, "Length of non existant element." );
|
||||
|
||||
@@ -1006,7 +1009,7 @@ test("replaceWith(String|Element|Array<Element>|jQuery)", function() {
|
||||
test("replaceWith(Function)", function() {
|
||||
testReplaceWith(functionReturningObj);
|
||||
|
||||
expect(22);
|
||||
expect(23);
|
||||
|
||||
var y = jQuery("#yahoo")[0];
|
||||
|
||||
|
||||
Reference in New Issue
Block a user