aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/core.js2
-rw-r--r--src/manipulation.js20
2 files changed, 12 insertions, 10 deletions
diff --git a/src/core.js b/src/core.js
index f116ef4d1..9af2882d7 100644
--- a/src/core.js
+++ b/src/core.js
@@ -130,7 +130,7 @@ jQuery.fn = jQuery.prototype = {
} else {
ret = jQuery.buildFragment( [ match[1] ], [ doc ] );
- selector = (ret.cacheable ? jQuery(ret.fragment).clone()[0] : ret.fragment).childNodes;
+ selector = (ret.cacheable ? jQuery.clone(ret.fragment) : ret.fragment).childNodes;
}
return jQuery.merge( this, selector );
diff --git a/src/manipulation.js b/src/manipulation.js
index af71ff62c..d758d803f 100644
--- a/src/manipulation.js
+++ b/src/manipulation.js
@@ -183,9 +183,12 @@ jQuery.fn.extend({
return this;
},
- clone: function( events, deepData ) {
+ clone: function( dataAndEvents, deepDataAndEvents ) {
+ dataAndEvents = dataAndEvents == null ? true : dataAndEvents;
+ deepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents;
+
return this.map( function () {
- return jQuery.clone( this, events == null ? true : events, deepData == null ? true : deepData );
+ return jQuery.clone( this, dataAndEvents, deepDataAndEvents );
});
},
@@ -480,13 +483,12 @@ jQuery.each({
});
jQuery.extend({
- clone: function( elem, dataAndEvents, deepCloneDataAndEvents ) {
-
+ clone: function( elem, dataAndEvents, deepDataAndEvents ) {
var clone = elem.cloneNode(true),
srcElements,
destElements;
- if ( !jQuery.support.noCloneEvent && ( elem.nodeType === 1 || elem.nodeType === 11) && !jQuery.isXMLDoc(elem) ) {
+ if ( !jQuery.support.noCloneEvent && (elem.nodeType === 1 || elem.nodeType === 11) && !jQuery.isXMLDoc(elem) ) {
// IE copies events bound via attachEvent when using cloneNode.
// Calling detachEvent on the clone will also remove the events
// from the original. In order to get around this, we use some
@@ -509,17 +511,17 @@ jQuery.extend({
}
// Copy the events from the original to the clone
- if ( dataAndEvents === true ) {
+ if ( dataAndEvents ) {
- cloneCopyEvent( elem , clone );
+ cloneCopyEvent( elem, clone );
- if ( deepCloneDataAndEvents === true && "getElementsByTagName" in elem ) {
+ if ( deepDataAndEvents && "getElementsByTagName" in elem ) {
srcElements = elem.getElementsByTagName("*");
destElements = clone.getElementsByTagName("*");
if ( srcElements.length ) {
- for ( var i = 0; i < srcElements.length; ++i ) {
+ for ( var i = 0; srcElements[i]; ++i ) {
cloneCopyEvent( srcElements[i], destElements[i] );
}
}