aboutsummaryrefslogtreecommitdiffstats
path: root/src/manipulation.js
diff options
context:
space:
mode:
authorRick Waldron <waldron.rick@gmail.com>2012-03-02 12:03:32 -0500
committerDave Methvin <dave.methvin@gmail.com>2012-03-02 12:03:32 -0500
commit1ff284d2cd67f2f4e7cd8b9577191ba80d521763 (patch)
tree07701c1532e568c3c5f2125097bfaa4c6eaf7e79 /src/manipulation.js
parent5cae50e66e34c277412c01ccb1c24bd6a85d2d8a (diff)
downloadjquery-1ff284d2cd67f2f4e7cd8b9577191ba80d521763.tar.gz
jquery-1ff284d2cd67f2f4e7cd8b9577191ba80d521763.zip
Fix #11356. Avoid hoarding elements in DocumentFragments.
Diffstat (limited to 'src/manipulation.js')
-rw-r--r--src/manipulation.js15
1 files changed, 14 insertions, 1 deletions
diff --git a/src/manipulation.js b/src/manipulation.js
index 220e09d46..954d52edf 100644
--- a/src/manipulation.js
+++ b/src/manipulation.js
@@ -676,7 +676,9 @@ jQuery.extend({
var tag = ( rtagName.exec( elem ) || ["", ""] )[1].toLowerCase(),
wrap = wrapMap[ tag ] || wrapMap._default,
depth = wrap[0],
- div = context.createElement("div");
+ div = context.createElement("div"),
+ safeChildNodes = safeFragment.childNodes,
+ remove;
// Append wrapper element to unknown element safe doc fragment
if ( context === document ) {
@@ -721,6 +723,17 @@ jQuery.extend({
}
elem = div.childNodes;
+
+ // Clear elements from DocumentFragment (safeFragment or otherwise)
+ // to avoid hoarding elements. Fixes #11356
+ if ( div ) {
+ div.parentNode.removeChild( div );
+ remove = safeChildNodes[ safeChildNodes.length - 1 ];
+
+ if ( remove && remove.parentNode ) {
+ remove.parentNode.removeChild( remove );
+ }
+ }
}
}