1 import jQuery from "./core.js";
2 import isAttached from "./core/isAttached.js";
3 import isIE from "./var/isIE.js";
4 import push from "./var/push.js";
5 import access from "./core/access.js";
6 import rtagName from "./manipulation/var/rtagName.js";
7 import wrapMap from "./manipulation/wrapMap.js";
8 import getAll from "./manipulation/getAll.js";
9 import domManip from "./manipulation/domManip.js";
10 import setGlobalEval from "./manipulation/setGlobalEval.js";
11 import dataPriv from "./data/var/dataPriv.js";
12 import dataUser from "./data/var/dataUser.js";
13 import acceptData from "./data/var/acceptData.js";
14 import nodeName from "./core/nodeName.js";
16 import "./core/init.js";
17 import "./traversing.js";
18 import "./selector.js";
23 // Support: IE <=10 - 11+
24 // In IE using regex groups here causes severe slowdowns.
25 rnoInnerhtml = /<script|<style|<link/i;
27 // Prefer a tbody over its parent table for containing new rows
28 function manipulationTarget( elem, content ) {
29 if ( nodeName( elem, "table" ) &&
30 nodeName( content.nodeType !== 11 ? content : content.firstChild, "tr" ) ) {
32 return jQuery( elem ).children( "tbody" )[ 0 ] || elem;
38 function cloneCopyEvent( src, dest ) {
39 var i, l, type, pdataOld, udataOld, udataCur, events;
41 if ( dest.nodeType !== 1 ) {
45 // 1. Copy private data: events, handlers, etc.
46 if ( dataPriv.hasData( src ) ) {
47 pdataOld = dataPriv.get( src );
48 events = pdataOld.events;
51 dataPriv.remove( dest, "handle events" );
53 for ( type in events ) {
54 for ( i = 0, l = events[ type ].length; i < l; i++ ) {
55 jQuery.event.add( dest, type, events[ type ][ i ] );
62 if ( dataUser.hasData( src ) ) {
63 udataOld = dataUser.access( src );
64 udataCur = jQuery.extend( {}, udataOld );
66 dataUser.set( dest, udataCur );
70 function remove( elem, selector, keepData ) {
72 nodes = selector ? jQuery.filter( selector, elem ) : elem,
75 for ( ; ( node = nodes[ i ] ) != null; i++ ) {
76 if ( !keepData && node.nodeType === 1 ) {
77 jQuery.cleanData( getAll( node ) );
80 if ( node.parentNode ) {
81 if ( keepData && isAttached( node ) ) {
82 setGlobalEval( getAll( node, "script" ) );
84 node.parentNode.removeChild( node );
92 htmlPrefilter: function( html ) {
96 clone: function( elem, dataAndEvents, deepDataAndEvents ) {
97 var i, l, srcElements, destElements,
98 clone = elem.cloneNode( true ),
99 inPage = isAttached( elem );
101 // Fix IE cloning issues
102 if ( isIE && ( elem.nodeType === 1 || elem.nodeType === 11 ) &&
103 !jQuery.isXMLDoc( elem ) ) {
105 // We eschew jQuery#find here for performance reasons:
106 // https://jsperf.com/getall-vs-sizzle/2
107 destElements = getAll( clone );
108 srcElements = getAll( elem );
110 for ( i = 0, l = srcElements.length; i < l; i++ ) {
113 // IE fails to set the defaultValue to the correct value when
114 // cloning textareas.
115 if ( nodeName( destElements[ i ], "textarea" ) ) {
116 destElements[ i ].defaultValue = srcElements[ i ].defaultValue;
121 // Copy the events from the original to the clone
122 if ( dataAndEvents ) {
123 if ( deepDataAndEvents ) {
124 srcElements = srcElements || getAll( elem );
125 destElements = destElements || getAll( clone );
127 for ( i = 0, l = srcElements.length; i < l; i++ ) {
128 cloneCopyEvent( srcElements[ i ], destElements[ i ] );
131 cloneCopyEvent( elem, clone );
135 // Preserve script evaluation history
136 destElements = getAll( clone, "script" );
137 if ( destElements.length > 0 ) {
138 setGlobalEval( destElements, !inPage && getAll( elem, "script" ) );
141 // Return the cloned set
145 cleanData: function( elems ) {
146 var data, elem, type,
147 special = jQuery.event.special,
150 for ( ; ( elem = elems[ i ] ) !== undefined; i++ ) {
151 if ( acceptData( elem ) ) {
152 if ( ( data = elem[ dataPriv.expando ] ) ) {
154 for ( type in data.events ) {
155 if ( special[ type ] ) {
156 jQuery.event.remove( elem, type );
158 // This is a shortcut to avoid jQuery.event.remove's overhead
160 jQuery.removeEvent( elem, type, data.handle );
165 // Support: Chrome <=35 - 45+
166 // Assign undefined instead of using delete, see Data#remove
167 elem[ dataPriv.expando ] = undefined;
169 if ( elem[ dataUser.expando ] ) {
171 // Support: Chrome <=35 - 45+
172 // Assign undefined instead of using delete, see Data#remove
173 elem[ dataUser.expando ] = undefined;
181 detach: function( selector ) {
182 return remove( this, selector, true );
185 remove: function( selector ) {
186 return remove( this, selector );
189 text: function( value ) {
190 return access( this, function( value ) {
191 return value === undefined ?
192 jQuery.text( this ) :
193 this.empty().each( function() {
194 if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {
195 this.textContent = value;
198 }, null, value, arguments.length );
202 return domManip( this, arguments, function( elem ) {
203 if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {
204 var target = manipulationTarget( this, elem );
205 target.appendChild( elem );
210 prepend: function() {
211 return domManip( this, arguments, function( elem ) {
212 if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {
213 var target = manipulationTarget( this, elem );
214 target.insertBefore( elem, target.firstChild );
220 return domManip( this, arguments, function( elem ) {
221 if ( this.parentNode ) {
222 this.parentNode.insertBefore( elem, this );
228 return domManip( this, arguments, function( elem ) {
229 if ( this.parentNode ) {
230 this.parentNode.insertBefore( elem, this.nextSibling );
239 for ( ; ( elem = this[ i ] ) != null; i++ ) {
240 if ( elem.nodeType === 1 ) {
242 // Prevent memory leaks
243 jQuery.cleanData( getAll( elem, false ) );
245 // Remove any remaining nodes
246 elem.textContent = "";
253 clone: function( dataAndEvents, deepDataAndEvents ) {
254 dataAndEvents = dataAndEvents == null ? false : dataAndEvents;
255 deepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents;
257 return this.map( function() {
258 return jQuery.clone( this, dataAndEvents, deepDataAndEvents );
262 html: function( value ) {
263 return access( this, function( value ) {
264 var elem = this[ 0 ] || {},
268 if ( value === undefined && elem.nodeType === 1 ) {
269 return elem.innerHTML;
272 // See if we can take a shortcut and just use innerHTML
273 if ( typeof value === "string" && !rnoInnerhtml.test( value ) &&
274 !wrapMap[ ( rtagName.exec( value ) || [ "", "" ] )[ 1 ].toLowerCase() ] ) {
276 value = jQuery.htmlPrefilter( value );
279 for ( ; i < l; i++ ) {
280 elem = this[ i ] || {};
282 // Remove element nodes and prevent memory leaks
283 if ( elem.nodeType === 1 ) {
284 jQuery.cleanData( getAll( elem, false ) );
285 elem.innerHTML = value;
291 // If using innerHTML throws an exception, use the fallback method
296 this.empty().append( value );
298 }, null, value, arguments.length );
301 replaceWith: function() {
304 // Make the changes, replacing each non-ignored context element with the new content
305 return domManip( this, arguments, function( elem ) {
306 var parent = this.parentNode;
308 if ( jQuery.inArray( this, ignored ) < 0 ) {
309 jQuery.cleanData( getAll( this ) );
311 parent.replaceChild( elem, this );
315 // Force callback invocation
322 prependTo: "prepend",
323 insertBefore: "before",
324 insertAfter: "after",
325 replaceAll: "replaceWith"
326 }, function( name, original ) {
327 jQuery.fn[ name ] = function( selector ) {
330 insert = jQuery( selector ),
331 last = insert.length - 1,
334 for ( ; i <= last; i++ ) {
335 elems = i === last ? this : this.clone( true );
336 jQuery( insert[ i ] )[ original ]( elems );
337 push.apply( ret, elems.get() );
340 return this.pushStack( ret );
344 export default jQuery;