1 import jQuery from "./core.js";
2 import isAttached from "./core/isAttached.js";
3 import flat from "./var/flat.js";
4 import isIE from "./var/isIE.js";
5 import push from "./var/push.js";
6 import access from "./core/access.js";
7 import rtagName from "./manipulation/var/rtagName.js";
8 import rscriptType from "./manipulation/var/rscriptType.js";
9 import wrapMap from "./manipulation/wrapMap.js";
10 import getAll from "./manipulation/getAll.js";
11 import setGlobalEval from "./manipulation/setGlobalEval.js";
12 import buildFragment from "./manipulation/buildFragment.js";
13 import dataPriv from "./data/var/dataPriv.js";
14 import dataUser from "./data/var/dataUser.js";
15 import acceptData from "./data/var/acceptData.js";
16 import DOMEval from "./core/DOMEval.js";
17 import nodeName from "./core/nodeName.js";
19 import "./core/init.js";
20 import "./traversing.js";
21 import "./selector.js";
26 // Support: IE <=10 - 11+
27 // In IE using regex groups here causes severe slowdowns.
28 rnoInnerhtml = /<script|<style|<link/i,
30 rcleanScript = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;
32 // Prefer a tbody over its parent table for containing new rows
33 function manipulationTarget( elem, content ) {
34 if ( nodeName( elem, "table" ) &&
35 nodeName( content.nodeType !== 11 ? content : content.firstChild, "tr" ) ) {
37 return jQuery( elem ).children( "tbody" )[ 0 ] || elem;
43 // Replace/restore the type attribute of script elements for safe DOM manipulation
44 function disableScript( elem ) {
45 elem.type = ( elem.getAttribute( "type" ) !== null ) + "/" + elem.type;
48 function restoreScript( elem ) {
49 if ( ( elem.type || "" ).slice( 0, 5 ) === "true/" ) {
50 elem.type = elem.type.slice( 5 );
52 elem.removeAttribute( "type" );
58 function cloneCopyEvent( src, dest ) {
59 var i, l, type, pdataOld, udataOld, udataCur, events;
61 if ( dest.nodeType !== 1 ) {
65 // 1. Copy private data: events, handlers, etc.
66 if ( dataPriv.hasData( src ) ) {
67 pdataOld = dataPriv.get( src );
68 events = pdataOld.events;
71 dataPriv.remove( dest, "handle events" );
73 for ( type in events ) {
74 for ( i = 0, l = events[ type ].length; i < l; i++ ) {
75 jQuery.event.add( dest, type, events[ type ][ i ] );
82 if ( dataUser.hasData( src ) ) {
83 udataOld = dataUser.access( src );
84 udataCur = jQuery.extend( {}, udataOld );
86 dataUser.set( dest, udataCur );
90 function domManip( collection, args, callback, ignored ) {
92 // Flatten any nested arrays
95 var fragment, first, scripts, hasScripts, node, doc,
97 l = collection.length,
100 valueIsFunction = typeof value === "function";
102 if ( valueIsFunction ) {
103 return collection.each( function( index ) {
104 var self = collection.eq( index );
105 args[ 0 ] = value.call( this, index, self.html() );
106 domManip( self, args, callback, ignored );
111 fragment = buildFragment( args, collection[ 0 ].ownerDocument, false, collection, ignored );
112 first = fragment.firstChild;
114 if ( fragment.childNodes.length === 1 ) {
118 // Require either new content or an interest in ignored elements to invoke the callback
119 if ( first || ignored ) {
120 scripts = jQuery.map( getAll( fragment, "script" ), disableScript );
121 hasScripts = scripts.length;
123 // Use the original fragment for the last item
124 // instead of the first because it can end up
125 // being emptied incorrectly in certain situations (#8070).
126 for ( ; i < l; i++ ) {
129 if ( i !== iNoClone ) {
130 node = jQuery.clone( node, true, true );
132 // Keep references to cloned scripts for later restoration
134 jQuery.merge( scripts, getAll( node, "script" ) );
138 callback.call( collection[ i ], node, i );
142 doc = scripts[ scripts.length - 1 ].ownerDocument;
145 jQuery.map( scripts, restoreScript );
147 // Evaluate executable scripts on first document insertion
148 for ( i = 0; i < hasScripts; i++ ) {
150 if ( rscriptType.test( node.type || "" ) &&
151 !dataPriv.access( node, "globalEval" ) &&
152 jQuery.contains( doc, node ) ) {
154 if ( node.src && ( node.type || "" ).toLowerCase() !== "module" ) {
156 // Optional AJAX dependency, but won't run scripts if not present
157 if ( jQuery._evalUrl && !node.noModule ) {
158 jQuery._evalUrl( node.src, {
160 crossOrigin: node.crossOrigin
164 DOMEval( node.textContent.replace( rcleanScript, "" ), node, doc );
175 function remove( elem, selector, keepData ) {
177 nodes = selector ? jQuery.filter( selector, elem ) : elem,
180 for ( ; ( node = nodes[ i ] ) != null; i++ ) {
181 if ( !keepData && node.nodeType === 1 ) {
182 jQuery.cleanData( getAll( node ) );
185 if ( node.parentNode ) {
186 if ( keepData && isAttached( node ) ) {
187 setGlobalEval( getAll( node, "script" ) );
189 node.parentNode.removeChild( node );
197 htmlPrefilter: function( html ) {
201 clone: function( elem, dataAndEvents, deepDataAndEvents ) {
202 var i, l, srcElements, destElements,
203 clone = elem.cloneNode( true ),
204 inPage = isAttached( elem );
206 // Fix IE cloning issues
207 if ( isIE && ( elem.nodeType === 1 || elem.nodeType === 11 ) &&
208 !jQuery.isXMLDoc( elem ) ) {
210 // We eschew jQuery#find here for performance reasons:
211 // https://jsperf.com/getall-vs-sizzle/2
212 destElements = getAll( clone );
213 srcElements = getAll( elem );
215 for ( i = 0, l = srcElements.length; i < l; i++ ) {
218 // IE fails to set the defaultValue to the correct value when
219 // cloning textareas.
220 if ( nodeName( destElements[ i ], "textarea" ) ) {
221 destElements[ i ].defaultValue = srcElements[ i ].defaultValue;
226 // Copy the events from the original to the clone
227 if ( dataAndEvents ) {
228 if ( deepDataAndEvents ) {
229 srcElements = srcElements || getAll( elem );
230 destElements = destElements || getAll( clone );
232 for ( i = 0, l = srcElements.length; i < l; i++ ) {
233 cloneCopyEvent( srcElements[ i ], destElements[ i ] );
236 cloneCopyEvent( elem, clone );
240 // Preserve script evaluation history
241 destElements = getAll( clone, "script" );
242 if ( destElements.length > 0 ) {
243 setGlobalEval( destElements, !inPage && getAll( elem, "script" ) );
246 // Return the cloned set
250 cleanData: function( elems ) {
251 var data, elem, type,
252 special = jQuery.event.special,
255 for ( ; ( elem = elems[ i ] ) !== undefined; i++ ) {
256 if ( acceptData( elem ) ) {
257 if ( ( data = elem[ dataPriv.expando ] ) ) {
259 for ( type in data.events ) {
260 if ( special[ type ] ) {
261 jQuery.event.remove( elem, type );
263 // This is a shortcut to avoid jQuery.event.remove's overhead
265 jQuery.removeEvent( elem, type, data.handle );
270 // Support: Chrome <=35 - 45+
271 // Assign undefined instead of using delete, see Data#remove
272 elem[ dataPriv.expando ] = undefined;
274 if ( elem[ dataUser.expando ] ) {
276 // Support: Chrome <=35 - 45+
277 // Assign undefined instead of using delete, see Data#remove
278 elem[ dataUser.expando ] = undefined;
286 detach: function( selector ) {
287 return remove( this, selector, true );
290 remove: function( selector ) {
291 return remove( this, selector );
294 text: function( value ) {
295 return access( this, function( value ) {
296 return value === undefined ?
297 jQuery.text( this ) :
298 this.empty().each( function() {
299 if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {
300 this.textContent = value;
303 }, null, value, arguments.length );
307 return domManip( this, arguments, function( elem ) {
308 if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {
309 var target = manipulationTarget( this, elem );
310 target.appendChild( elem );
315 prepend: function() {
316 return domManip( this, arguments, function( elem ) {
317 if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {
318 var target = manipulationTarget( this, elem );
319 target.insertBefore( elem, target.firstChild );
325 return domManip( this, arguments, function( elem ) {
326 if ( this.parentNode ) {
327 this.parentNode.insertBefore( elem, this );
333 return domManip( this, arguments, function( elem ) {
334 if ( this.parentNode ) {
335 this.parentNode.insertBefore( elem, this.nextSibling );
344 for ( ; ( elem = this[ i ] ) != null; i++ ) {
345 if ( elem.nodeType === 1 ) {
347 // Prevent memory leaks
348 jQuery.cleanData( getAll( elem, false ) );
350 // Remove any remaining nodes
351 elem.textContent = "";
358 clone: function( dataAndEvents, deepDataAndEvents ) {
359 dataAndEvents = dataAndEvents == null ? false : dataAndEvents;
360 deepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents;
362 return this.map( function() {
363 return jQuery.clone( this, dataAndEvents, deepDataAndEvents );
367 html: function( value ) {
368 return access( this, function( value ) {
369 var elem = this[ 0 ] || {},
373 if ( value === undefined && elem.nodeType === 1 ) {
374 return elem.innerHTML;
377 // See if we can take a shortcut and just use innerHTML
378 if ( typeof value === "string" && !rnoInnerhtml.test( value ) &&
379 !wrapMap[ ( rtagName.exec( value ) || [ "", "" ] )[ 1 ].toLowerCase() ] ) {
381 value = jQuery.htmlPrefilter( value );
384 for ( ; i < l; i++ ) {
385 elem = this[ i ] || {};
387 // Remove element nodes and prevent memory leaks
388 if ( elem.nodeType === 1 ) {
389 jQuery.cleanData( getAll( elem, false ) );
390 elem.innerHTML = value;
396 // If using innerHTML throws an exception, use the fallback method
401 this.empty().append( value );
403 }, null, value, arguments.length );
406 replaceWith: function() {
409 // Make the changes, replacing each non-ignored context element with the new content
410 return domManip( this, arguments, function( elem ) {
411 var parent = this.parentNode;
413 if ( jQuery.inArray( this, ignored ) < 0 ) {
414 jQuery.cleanData( getAll( this ) );
416 parent.replaceChild( elem, this );
420 // Force callback invocation
427 prependTo: "prepend",
428 insertBefore: "before",
429 insertAfter: "after",
430 replaceAll: "replaceWith"
431 }, function( name, original ) {
432 jQuery.fn[ name ] = function( selector ) {
435 insert = jQuery( selector ),
436 last = insert.length - 1,
439 for ( ; i <= last; i++ ) {
440 elems = i === last ? this : this.clone( true );
441 jQuery( insert[ i ] )[ original ]( elems );
442 push.apply( ret, elems.get() );
445 return this.pushStack( ret );
449 export default jQuery;