Skip to content
Permalink
Browse files

Ensure innerHTML of src/dest clone nodes is correctly set. Fixes #10324

Signed-off-by: Rick Waldron waldron.rick@gmail.com <waldron.rick@gmail.com>
  • Loading branch information...
rwaldron committed Mar 23, 2012
1 parent 379a137 commit 2795a8390c1986200bf4e00158dbf3ad2da8d898
Showing with 8 additions and 0 deletions.
  1. +7 −0 src/manipulation.js
  2. +1 −0 test/index.html
@@ -435,6 +435,13 @@ function cloneFixAttributes( src, dest ) {
if ( nodeName === "object" ) {
dest.outerHTML = src.outerHTML;

// This path appears unavoidable for IE9. When cloning an object
// element in IE9, the outerHTML strategy above is not sufficient.
// If the src has innerHTML and the destination does not,
// copy the src.innerHTML into the dest.innerHTML. #10324
if ( jQuery.support.html5Clone && (src.innerHTML && !jQuery.trim(dest.innerHTML)) ) {
dest.innerHTML = src.innerHTML;
}
} else if ( nodeName === "input" && (src.type === "checkbox" || src.type === "radio") ) {
// IE6-8 fails to persist the checked state of a cloned checkbox
// or radio button. Worse, IE6-7 fail to give the cloned element
@@ -135,6 +135,7 @@ <h2 id="qunit-userAgent"></h2>
<param name="p1" value="x1" />
<param name="p2" value="x2" />
</object>
<object id="object2"><param name="test" value="test"></param></object>​

<span id="台北Táiběi"></span>
<span id="台北" lang="中文"></span>

0 comments on commit 2795a83

Please sign in to comment.
You can’t perform that action at this time.