scratch – Diff between revs 58 and 125

Subversion Repositories:
Rev:
Only display areas with differencesIgnore whitespace
Rev 58 Rev 125
1 /* global Symbol */ -  
2 // Defining this global in .eslintrc.json would create a danger of using the global -  
3 // unguarded in another place, it seems safer to define global only for this module -  
4   -  
5 define( [ 1 define([
6 "./var/arr", 2 "./var/arr",
7 "./var/document", -  
8 "./var/getProto", -  
9 "./var/slice", 3 "./var/slice",
10 "./var/concat", 4 "./var/concat",
11 "./var/push", 5 "./var/push",
12 "./var/indexOf", 6 "./var/indexOf",
13 "./var/class2type", 7 "./var/class2type",
14 "./var/toString", 8 "./var/toString",
15 "./var/hasOwn", 9 "./var/hasOwn",
16 "./var/fnToString", -  
17 "./var/ObjectFunctionString", -  
18 "./var/support", 10 "./var/support"
19 "./core/DOMEval" -  
20 ], function( arr, document, getProto, slice, concat, push, indexOf, 11 ], function( arr, slice, concat, push, indexOf, class2type, toString, hasOwn, support ) {
21 class2type, toString, hasOwn, fnToString, ObjectFunctionString, -  
22 support, DOMEval ) { -  
23   -  
24 "use strict"; -  
25   12  
-   13 var
-   14 // Use the correct document accordingly with window argument (sandbox)
-   15 document = window.document,
26 var 16  
27 version = "3.1.1", 17 version = "@VERSION",
28   18  
29 // Define a local copy of jQuery 19 // Define a local copy of jQuery
30 jQuery = function( selector, context ) { 20 jQuery = function( selector, context ) {
31   -  
32 // The jQuery object is actually just the init constructor 'enhanced' 21 // The jQuery object is actually just the init constructor 'enhanced'
33 // Need init if jQuery is called (just allow error to be thrown if not included) 22 // Need init if jQuery is called (just allow error to be thrown if not included)
34 return new jQuery.fn.init( selector, context ); 23 return new jQuery.fn.init( selector, context );
35 }, 24 },
36   25  
37 // Support: Android <=4.0 only 26 // Support: Android<4.1
38 // Make sure we trim BOM and NBSP 27 // Make sure we trim BOM and NBSP
39 rtrim = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, 28 rtrim = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,
40   29  
41 // Matches dashed string for camelizing 30 // Matches dashed string for camelizing
42 rmsPrefix = /^-ms-/, 31 rmsPrefix = /^-ms-/,
43 rdashAlpha = /-([a-z])/g, 32 rdashAlpha = /-([\da-z])/gi,
44   33  
45 // Used by jQuery.camelCase as callback to replace() 34 // Used by jQuery.camelCase as callback to replace()
46 fcamelCase = function( all, letter ) { 35 fcamelCase = function( all, letter ) {
47 return letter.toUpperCase(); 36 return letter.toUpperCase();
48 }; 37 };
49   38  
50 jQuery.fn = jQuery.prototype = { 39 jQuery.fn = jQuery.prototype = {
51   -  
52 // The current version of jQuery being used 40 // The current version of jQuery being used
53 jquery: version, 41 jquery: version,
54   42  
55 constructor: jQuery, 43 constructor: jQuery,
-   44  
-   45 // Start with an empty selector
-   46 selector: "",
56   47  
57 // The default length of a jQuery object is 0 48 // The default length of a jQuery object is 0
58 length: 0, 49 length: 0,
59   50  
60 toArray: function() { 51 toArray: function() {
61 return slice.call( this ); 52 return slice.call( this );
62 }, 53 },
63   54  
64 // Get the Nth element in the matched element set OR 55 // Get the Nth element in the matched element set OR
65 // Get the whole matched element set as a clean array 56 // Get the whole matched element set as a clean array
66 get: function( num ) { 57 get: function( num ) {
-   58 return num != null ?
67   59  
68 // Return all the elements in a clean array -  
69 if ( num == null ) { 60 // Return just the one element from the set
70 return slice.call( this ); -  
71 } 61 ( num < 0 ? this[ num + this.length ] : this[ num ] ) :
72   62  
73 // Return just the one element from the set 63 // Return all the elements in a clean array
74 return num < 0 ? this[ num + this.length ] : this[ num ]; 64 slice.call( this );
75 }, 65 },
76   66  
77 // Take an array of elements and push it onto the stack 67 // Take an array of elements and push it onto the stack
78 // (returning the new matched element set) 68 // (returning the new matched element set)
79 pushStack: function( elems ) { 69 pushStack: function( elems ) {
80   70  
81 // Build a new jQuery matched element set 71 // Build a new jQuery matched element set
82 var ret = jQuery.merge( this.constructor(), elems ); 72 var ret = jQuery.merge( this.constructor(), elems );
83   73  
84 // Add the old object onto the stack (as a reference) 74 // Add the old object onto the stack (as a reference)
85 ret.prevObject = this; 75 ret.prevObject = this;
-   76 ret.context = this.context;
86   77  
87 // Return the newly-formed element set 78 // Return the newly-formed element set
88 return ret; 79 return ret;
89 }, 80 },
90   81  
91 // Execute a callback for every element in the matched set. 82 // Execute a callback for every element in the matched set.
-   83 // (You can seed the arguments with an array of args, but this is
-   84 // only used internally.)
92 each: function( callback ) { 85 each: function( callback, args ) {
93 return jQuery.each( this, callback ); 86 return jQuery.each( this, callback, args );
94 }, 87 },
95   88  
96 map: function( callback ) { 89 map: function( callback ) {
97 return this.pushStack( jQuery.map( this, function( elem, i ) { 90 return this.pushStack( jQuery.map(this, function( elem, i ) {
98 return callback.call( elem, i, elem ); 91 return callback.call( elem, i, elem );
99 } ) ); 92 }));
100 }, 93 },
101   94  
102 slice: function() { 95 slice: function() {
103 return this.pushStack( slice.apply( this, arguments ) ); 96 return this.pushStack( slice.apply( this, arguments ) );
104 }, 97 },
105   98  
106 first: function() { 99 first: function() {
107 return this.eq( 0 ); 100 return this.eq( 0 );
108 }, 101 },
109   102  
110 last: function() { 103 last: function() {
111 return this.eq( -1 ); 104 return this.eq( -1 );
112 }, 105 },
113   106  
114 eq: function( i ) { 107 eq: function( i ) {
115 var len = this.length, 108 var len = this.length,
116 j = +i + ( i < 0 ? len : 0 ); 109 j = +i + ( i < 0 ? len : 0 );
117 return this.pushStack( j >= 0 && j < len ? [ this[ j ] ] : [] ); 110 return this.pushStack( j >= 0 && j < len ? [ this[j] ] : [] );
118 }, 111 },
119   112  
120 end: function() { 113 end: function() {
121 return this.prevObject || this.constructor(); 114 return this.prevObject || this.constructor(null);
122 }, 115 },
123   116  
124 // For internal use only. 117 // For internal use only.
125 // Behaves like an Array's method, not like a jQuery method. 118 // Behaves like an Array's method, not like a jQuery method.
126 push: push, 119 push: push,
127 sort: arr.sort, 120 sort: arr.sort,
128 splice: arr.splice 121 splice: arr.splice
129 }; 122 };
130   123  
131 jQuery.extend = jQuery.fn.extend = function() { 124 jQuery.extend = jQuery.fn.extend = function() {
132 var options, name, src, copy, copyIsArray, clone, 125 var options, name, src, copy, copyIsArray, clone,
133 target = arguments[ 0 ] || {}, 126 target = arguments[0] || {},
134 i = 1, 127 i = 1,
135 length = arguments.length, 128 length = arguments.length,
136 deep = false; 129 deep = false;
137   130  
138 // Handle a deep copy situation 131 // Handle a deep copy situation
139 if ( typeof target === "boolean" ) { 132 if ( typeof target === "boolean" ) {
140 deep = target; 133 deep = target;
141   134  
142 // Skip the boolean and the target 135 // Skip the boolean and the target
143 target = arguments[ i ] || {}; 136 target = arguments[ i ] || {};
144 i++; 137 i++;
145 } 138 }
146   139  
147 // Handle case when target is a string or something (possible in deep copy) 140 // Handle case when target is a string or something (possible in deep copy)
148 if ( typeof target !== "object" && !jQuery.isFunction( target ) ) { 141 if ( typeof target !== "object" && !jQuery.isFunction(target) ) {
149 target = {}; 142 target = {};
150 } 143 }
151   144  
152 // Extend jQuery itself if only one argument is passed 145 // Extend jQuery itself if only one argument is passed
153 if ( i === length ) { 146 if ( i === length ) {
154 target = this; 147 target = this;
155 i--; 148 i--;
156 } 149 }
157   150  
158 for ( ; i < length; i++ ) { 151 for ( ; i < length; i++ ) {
159   -  
160 // Only deal with non-null/undefined values 152 // Only deal with non-null/undefined values
161 if ( ( options = arguments[ i ] ) != null ) { 153 if ( (options = arguments[ i ]) != null ) {
162   -  
163 // Extend the base object 154 // Extend the base object
164 for ( name in options ) { 155 for ( name in options ) {
165 src = target[ name ]; 156 src = target[ name ];
166 copy = options[ name ]; 157 copy = options[ name ];
167   158  
168 // Prevent never-ending loop 159 // Prevent never-ending loop
169 if ( target === copy ) { 160 if ( target === copy ) {
170 continue; 161 continue;
171 } 162 }
172   163  
173 // Recurse if we're merging plain objects or arrays 164 // Recurse if we're merging plain objects or arrays
174 if ( deep && copy && ( jQuery.isPlainObject( copy ) || 165 if ( deep && copy && ( jQuery.isPlainObject(copy) || (copyIsArray = jQuery.isArray(copy)) ) ) {
175 ( copyIsArray = jQuery.isArray( copy ) ) ) ) { -  
176   -  
177 if ( copyIsArray ) { 166 if ( copyIsArray ) {
178 copyIsArray = false; 167 copyIsArray = false;
179 clone = src && jQuery.isArray( src ) ? src : []; 168 clone = src && jQuery.isArray(src) ? src : [];
180   169  
181 } else { 170 } else {
182 clone = src && jQuery.isPlainObject( src ) ? src : {}; 171 clone = src && jQuery.isPlainObject(src) ? src : {};
183 } 172 }
184   173  
185 // Never move original objects, clone them 174 // Never move original objects, clone them
186 target[ name ] = jQuery.extend( deep, clone, copy ); 175 target[ name ] = jQuery.extend( deep, clone, copy );
187   176  
188 // Don't bring in undefined values 177 // Don't bring in undefined values
189 } else if ( copy !== undefined ) { 178 } else if ( copy !== undefined ) {
190 target[ name ] = copy; 179 target[ name ] = copy;
191 } 180 }
192 } 181 }
193 } 182 }
194 } 183 }
195   184  
196 // Return the modified object 185 // Return the modified object
197 return target; 186 return target;
198 }; 187 };
199   188  
200 jQuery.extend( { -  
201   189 jQuery.extend({
202 // Unique for each copy of jQuery on the page 190 // Unique for each copy of jQuery on the page
203 expando: "jQuery" + ( version + Math.random() ).replace( /\D/g, "" ), 191 expando: "jQuery" + ( version + Math.random() ).replace( /\D/g, "" ),
204   192  
205 // Assume jQuery is ready without the ready module 193 // Assume jQuery is ready without the ready module
206 isReady: true, 194 isReady: true,
207   195  
208 error: function( msg ) { 196 error: function( msg ) {
209 throw new Error( msg ); 197 throw new Error( msg );
210 }, 198 },
211   199  
212 noop: function() {}, 200 noop: function() {},
213   201  
214 isFunction: function( obj ) { 202 isFunction: function( obj ) {
215 return jQuery.type( obj ) === "function"; 203 return jQuery.type(obj) === "function";
216 }, 204 },
217   205  
218 isArray: Array.isArray, 206 isArray: Array.isArray,
219   207  
220 isWindow: function( obj ) { 208 isWindow: function( obj ) {
221 return obj != null && obj === obj.window; 209 return obj != null && obj === obj.window;
222 }, 210 },
223   211  
224 isNumeric: function( obj ) { 212 isNumeric: function( obj ) {
225   -  
226 // As of jQuery 3.0, isNumeric is limited to -  
227 // strings and numbers (primitives or objects) -  
228 // that can be coerced to finite numbers (gh-2662) -  
229 var type = jQuery.type( obj ); -  
230 return ( type === "number" || type === "string" ) && -  
231   -  
232 // parseFloat NaNs numeric-cast false positives ("") 213 // parseFloat NaNs numeric-cast false positives (null|true|false|"")
233 // ...but misinterprets leading-number strings, particularly hex literals ("0x...") 214 // ...but misinterprets leading-number strings, particularly hex literals ("0x...")
234 // subtraction forces infinities to NaN 215 // subtraction forces infinities to NaN
-   216 // adding 1 corrects loss of precision from parseFloat (#15100)
235 !isNaN( obj - parseFloat( obj ) ); 217 return !jQuery.isArray( obj ) && (obj - parseFloat( obj ) + 1) >= 0;
236 }, 218 },
237   219  
238 isPlainObject: function( obj ) { 220 isPlainObject: function( obj ) {
239 var proto, Ctor; 221 // Not plain objects:
240   -  
-   222 // - Any object or value whose internal [[Class]] property is not "[object Object]"
241 // Detect obvious negatives 223 // - DOM nodes
242 // Use toString instead of jQuery.type to catch host objects 224 // - window
243 if ( !obj || toString.call( obj ) !== "[object Object]" ) { 225 if ( jQuery.type( obj ) !== "object" || obj.nodeType || jQuery.isWindow( obj ) ) {
244 return false; 226 return false;
245 } 227 }
246   228  
247 proto = getProto( obj ); -  
248   229 if ( obj.constructor &&
249 // Objects with no prototype (e.g., `Object.create( null )`) are plain -  
250 if ( !proto ) { 230 !hasOwn.call( obj.constructor.prototype, "isPrototypeOf" ) ) {
251 return true; 231 return false;
252 } 232 }
253   233  
254 // Objects with prototype are plain iff they were constructed by a global Object function 234 // If the function hasn't returned already, we're confident that
255 Ctor = hasOwn.call( proto, "constructor" ) && proto.constructor; 235 // |obj| is a plain object, created by {} or constructed with new Object
256 return typeof Ctor === "function" && fnToString.call( Ctor ) === ObjectFunctionString; 236 return true;
257 }, 237 },
258   238  
259 isEmptyObject: function( obj ) { 239 isEmptyObject: function( obj ) {
260   -  
261 /* eslint-disable no-unused-vars */ -  
262 // See https://github.com/eslint/eslint/issues/6125 -  
263 var name; 240 var name;
264   -  
265 for ( name in obj ) { 241 for ( name in obj ) {
266 return false; 242 return false;
267 } 243 }
268 return true; 244 return true;
269 }, 245 },
270   246  
271 type: function( obj ) { 247 type: function( obj ) {
272 if ( obj == null ) { 248 if ( obj == null ) {
273 return obj + ""; 249 return obj + "";
274 } 250 }
275   -  
276 // Support: Android <=2.3 only (functionish RegExp) 251 // Support: Android<4.0, iOS<6 (functionish RegExp)
277 return typeof obj === "object" || typeof obj === "function" ? 252 return typeof obj === "object" || typeof obj === "function" ?
278 class2type[ toString.call( obj ) ] || "object" : 253 class2type[ toString.call(obj) ] || "object" :
279 typeof obj; 254 typeof obj;
280 }, 255 },
281   256  
282 // Evaluates a script in a global context 257 // Evaluates a script in a global context
283 globalEval: function( code ) { 258 globalEval: function( code ) {
-   259 var script,
-   260 indirect = eval;
-   261  
-   262 code = jQuery.trim( code );
-   263  
-   264 if ( code ) {
-   265 // If the code includes a valid, prologue position
-   266 // strict mode pragma, execute code by injecting a
-   267 // script tag into the document.
-   268 if ( code.indexOf("use strict") === 1 ) {
-   269 script = document.createElement("script");
-   270 script.text = code;
-   271 document.head.appendChild( script ).parentNode.removeChild( script );
-   272 } else {
-   273 // Otherwise, avoid the DOM node creation, insertion
-   274 // and removal by using an indirect global eval
284 DOMEval( code ); 275 indirect( code );
-   276 }
-   277 }
285 }, 278 },
286   279  
287 // Convert dashed to camelCase; used by the css and data modules 280 // Convert dashed to camelCase; used by the css and data modules
288 // Support: IE <=9 - 11, Edge 12 - 13 281 // Support: IE9-11+
289 // Microsoft forgot to hump their vendor prefix (#9572) 282 // Microsoft forgot to hump their vendor prefix (#9572)
290 camelCase: function( string ) { 283 camelCase: function( string ) {
291 return string.replace( rmsPrefix, "ms-" ).replace( rdashAlpha, fcamelCase ); 284 return string.replace( rmsPrefix, "ms-" ).replace( rdashAlpha, fcamelCase );
292 }, 285 },
293   286  
294 nodeName: function( elem, name ) { 287 nodeName: function( elem, name ) {
295 return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); 288 return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase();
296 }, 289 },
-   290  
297   291 // args is for internal usage only
298 each: function( obj, callback ) { 292 each: function( obj, callback, args ) {
-   293 var value,
-   294 i = 0,
-   295 length = obj.length,
299 var length, i = 0; 296 isArray = isArraylike( obj );
300   297  
301 if ( isArrayLike( obj ) ) { 298 if ( args ) {
-   299 if ( isArray ) {
-   300 for ( ; i < length; i++ ) {
-   301 value = callback.apply( obj[ i ], args );
-   302  
-   303 if ( value === false ) {
-   304 break;
-   305 }
-   306 }
302 length = obj.length; 307 } else {
-   308 for ( i in obj ) {
-   309 value = callback.apply( obj[ i ], args );
303 for ( ; i < length; i++ ) { 310  
-   311 if ( value === false ) {
304 if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) { 312 break;
305 break; 313 }
-   314 }
-   315 }
306 } 316  
-   317 // A special, fast, case for the most common use of each
-   318 } else {
-   319 if ( isArray ) {
-   320 for ( ; i < length; i++ ) {
-   321 value = callback.call( obj[ i ], i, obj[ i ] );
-   322  
-   323 if ( value === false ) {
-   324 break;
-   325 }
307 } 326 }
308 } else { 327 } else {
-   328 for ( i in obj ) {
-   329 value = callback.call( obj[ i ], i, obj[ i ] );
309 for ( i in obj ) { 330  
-   331 if ( value === false ) {
310 if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) { 332 break;
311 break; 333 }
312 } 334 }
313 } 335 }
314 } 336 }
315   337  
316 return obj; 338 return obj;
317 }, 339 },
318   340  
319 // Support: Android <=4.0 only 341 // Support: Android<4.1
320 trim: function( text ) { 342 trim: function( text ) {
321 return text == null ? 343 return text == null ?
322 "" : 344 "" :
323 ( text + "" ).replace( rtrim, "" ); 345 ( text + "" ).replace( rtrim, "" );
324 }, 346 },
325   347  
326 // results is for internal usage only 348 // results is for internal usage only
327 makeArray: function( arr, results ) { 349 makeArray: function( arr, results ) {
328 var ret = results || []; 350 var ret = results || [];
329   351  
330 if ( arr != null ) { 352 if ( arr != null ) {
331 if ( isArrayLike( Object( arr ) ) ) { 353 if ( isArraylike( Object(arr) ) ) {
332 jQuery.merge( ret, 354 jQuery.merge( ret,
333 typeof arr === "string" ? 355 typeof arr === "string" ?
334 [ arr ] : arr 356 [ arr ] : arr
335 ); 357 );
336 } else { 358 } else {
337 push.call( ret, arr ); 359 push.call( ret, arr );
338 } 360 }
339 } 361 }
340   362  
341 return ret; 363 return ret;
342 }, 364 },
343   365  
344 inArray: function( elem, arr, i ) { 366 inArray: function( elem, arr, i ) {
345 return arr == null ? -1 : indexOf.call( arr, elem, i ); 367 return arr == null ? -1 : indexOf.call( arr, elem, i );
346 }, 368 },
347   -  
348 // Support: Android <=4.0 only, PhantomJS 1 only -  
349 // push.apply(_, arraylike) throws on ancient WebKit 369  
350 merge: function( first, second ) { 370 merge: function( first, second ) {
351 var len = +second.length, 371 var len = +second.length,
352 j = 0, 372 j = 0,
353 i = first.length; 373 i = first.length;
354   374  
355 for ( ; j < len; j++ ) { 375 for ( ; j < len; j++ ) {
356 first[ i++ ] = second[ j ]; 376 first[ i++ ] = second[ j ];
357 } 377 }
358   378  
359 first.length = i; 379 first.length = i;
360   380  
361 return first; 381 return first;
362 }, 382 },
363   383  
364 grep: function( elems, callback, invert ) { 384 grep: function( elems, callback, invert ) {
365 var callbackInverse, 385 var callbackInverse,
366 matches = [], 386 matches = [],
367 i = 0, 387 i = 0,
368 length = elems.length, 388 length = elems.length,
369 callbackExpect = !invert; 389 callbackExpect = !invert;
370   390  
371 // Go through the array, only saving the items 391 // Go through the array, only saving the items
372 // that pass the validator function 392 // that pass the validator function
373 for ( ; i < length; i++ ) { 393 for ( ; i < length; i++ ) {
374 callbackInverse = !callback( elems[ i ], i ); 394 callbackInverse = !callback( elems[ i ], i );
375 if ( callbackInverse !== callbackExpect ) { 395 if ( callbackInverse !== callbackExpect ) {
376 matches.push( elems[ i ] ); 396 matches.push( elems[ i ] );
377 } 397 }
378 } 398 }
379   399  
380 return matches; 400 return matches;
381 }, 401 },
382   402  
383 // arg is for internal usage only 403 // arg is for internal usage only
384 map: function( elems, callback, arg ) { 404 map: function( elems, callback, arg ) {
385 var length, value, 405 var value,
386 i = 0, 406 i = 0,
-   407 length = elems.length,
-   408 isArray = isArraylike( elems ),
387 ret = []; 409 ret = [];
388   410  
389 // Go through the array, translating each of the items to their new values 411 // Go through the array, translating each of the items to their new values
390 if ( isArrayLike( elems ) ) { 412 if ( isArray ) {
391 length = elems.length; -  
392 for ( ; i < length; i++ ) { 413 for ( ; i < length; i++ ) {
393 value = callback( elems[ i ], i, arg ); 414 value = callback( elems[ i ], i, arg );
394   415  
395 if ( value != null ) { 416 if ( value != null ) {
396 ret.push( value ); 417 ret.push( value );
397 } 418 }
398 } 419 }
399   420  
400 // Go through every key on the object, 421 // Go through every key on the object,
401 } else { 422 } else {
402 for ( i in elems ) { 423 for ( i in elems ) {
403 value = callback( elems[ i ], i, arg ); 424 value = callback( elems[ i ], i, arg );
404   425  
405 if ( value != null ) { 426 if ( value != null ) {
406 ret.push( value ); 427 ret.push( value );
407 } 428 }
408 } 429 }
409 } 430 }
410   431  
411 // Flatten any nested arrays 432 // Flatten any nested arrays
412 return concat.apply( [], ret ); 433 return concat.apply( [], ret );
413 }, 434 },
414   435  
415 // A global GUID counter for objects 436 // A global GUID counter for objects
416 guid: 1, 437 guid: 1,
417   438  
418 // Bind a function to a context, optionally partially applying any 439 // Bind a function to a context, optionally partially applying any
419 // arguments. 440 // arguments.
420 proxy: function( fn, context ) { 441 proxy: function( fn, context ) {
421 var tmp, args, proxy; 442 var tmp, args, proxy;
422   443  
423 if ( typeof context === "string" ) { 444 if ( typeof context === "string" ) {
424 tmp = fn[ context ]; 445 tmp = fn[ context ];
425 context = fn; 446 context = fn;
426 fn = tmp; 447 fn = tmp;
427 } 448 }
428   449  
429 // Quick check to determine if target is callable, in the spec 450 // Quick check to determine if target is callable, in the spec
430 // this throws a TypeError, but we will just return undefined. 451 // this throws a TypeError, but we will just return undefined.
431 if ( !jQuery.isFunction( fn ) ) { 452 if ( !jQuery.isFunction( fn ) ) {
432 return undefined; 453 return undefined;
433 } 454 }
434   455  
435 // Simulated bind 456 // Simulated bind
436 args = slice.call( arguments, 2 ); 457 args = slice.call( arguments, 2 );
437 proxy = function() { 458 proxy = function() {
438 return fn.apply( context || this, args.concat( slice.call( arguments ) ) ); 459 return fn.apply( context || this, args.concat( slice.call( arguments ) ) );
439 }; 460 };
440   461  
441 // Set the guid of unique handler to the same of original handler, so it can be removed 462 // Set the guid of unique handler to the same of original handler, so it can be removed
442 proxy.guid = fn.guid = fn.guid || jQuery.guid++; 463 proxy.guid = fn.guid = fn.guid || jQuery.guid++;
443   464  
444 return proxy; 465 return proxy;
445 }, 466 },
446   467  
447 now: Date.now, 468 now: Date.now,
448   469  
449 // jQuery.support is not used in Core but other projects attach their 470 // jQuery.support is not used in Core but other projects attach their
450 // properties to it so it needs to exist. 471 // properties to it so it needs to exist.
451 support: support 472 support: support
452 } ); 473 });
453   -  
454 if ( typeof Symbol === "function" ) { -  
455 jQuery.fn[ Symbol.iterator ] = arr[ Symbol.iterator ]; -  
456 } -  
457   474  
458 // Populate the class2type map 475 // Populate the class2type map
459 jQuery.each( "Boolean Number String Function Array Date RegExp Object Error Symbol".split( " " ), -  
460 function( i, name ) { 476 jQuery.each("Boolean Number String Function Array Date RegExp Object Error".split(" "), function(i, name) {
461 class2type[ "[object " + name + "]" ] = name.toLowerCase(); 477 class2type[ "[object " + name + "]" ] = name.toLowerCase();
462 } ); 478 });
463   479  
464 function isArrayLike( obj ) { 480 function isArraylike( obj ) {
465   481  
466 // Support: real iOS 8.2 only (not reproducible in simulator) 482 // Support: iOS 8.2 (not reproducible in simulator)
467 // `in` check used to prevent JIT error (gh-2145) 483 // `in` check used to prevent JIT error (gh-2145)
468 // hasOwn isn't used here due to false negatives 484 // hasOwn isn't used here due to false negatives
469 // regarding Nodelist length in IE 485 // regarding Nodelist length in IE
470 var length = !!obj && "length" in obj && obj.length, 486 var length = "length" in obj && obj.length,
471 type = jQuery.type( obj ); 487 type = jQuery.type( obj );
472   488  
473 if ( type === "function" || jQuery.isWindow( obj ) ) { 489 if ( type === "function" || jQuery.isWindow( obj ) ) {
474 return false; 490 return false;
475 } 491 }
-   492  
-   493 if ( obj.nodeType === 1 && length ) {
-   494 return true;
-   495 }
476   496  
477 return type === "array" || length === 0 || 497 return type === "array" || length === 0 ||
478 typeof length === "number" && length > 0 && ( length - 1 ) in obj; 498 typeof length === "number" && length > 0 && ( length - 1 ) in obj;
479 } 499 }
480   500  
481 return jQuery; 501 return jQuery;
482 } ); 502 });
483   503