X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=src%2Fcore.js;h=e2d3b60f75820f0a61cb6118625f0801e3314db8;hb=ad4f28631ac888e7ac8384b4b713012fd1ca2dca;hp=6eeb9a67eca4c3e1f808c7f3eb22ef8fef840c00;hpb=c2bbcd88335cf6f8df4ac9389ecbae90291377fb;p=jquery.git diff --git a/src/core.js b/src/core.js index 6eeb9a6..e2d3b60 100644 --- a/src/core.js +++ b/src/core.js @@ -29,10 +29,10 @@ var jQuery = function( selector, context ) { rnotwhite = /\S/, // Used for trimming whitespace - rtrim = /^\s+|\s+$/g, + rtrim = /(\s|\u00A0)+|(\s|\u00A0)+$/g, // Match a standalone tag - rsingleTag = /^<(\w+)\s*\/?>$/, + rsingleTag = /^<(\w+)\s*\/?>(?:<\/\1>)?$/, // Keep a UserAgent string for use with jQuery.browser userAgent = navigator.userAgent.toLowerCase(), @@ -56,7 +56,7 @@ jQuery.fn = jQuery.prototype = { // Handle $(DOMElement) if ( selector.nodeType ) { this.context = this[0] = selector; - this.length++; + this.length = 1; return this; } @@ -96,7 +96,7 @@ jQuery.fn = jQuery.prototype = { } // Otherwise, we inject the element directly into the jQuery object - this.length++; + this.length = 1; this[0] = elem; } @@ -132,9 +132,9 @@ jQuery.fn = jQuery.prototype = { this.context = selector.context; } - return this.setArray(jQuery.isArray( selector ) ? - selector : - jQuery.makeArray(selector)); + return jQuery.isArray( selector ) ? + this.setArray( selector ) : + jQuery.makeArray( selector, this ); }, // Start with an empty selector @@ -272,19 +272,10 @@ jQuery.extend = jQuery.fn.extend = function() { continue; } - // Recurse if we're merging object values - if ( deep && copy && typeof copy === "object" && !copy.nodeType ) { - var clone; - - if ( src ) { - clone = src; - } else if ( jQuery.isArray(copy) ) { - clone = []; - } else if ( jQuery.isObject(copy) ) { - clone = {}; - } else { - clone = copy; - } + // Recurse if we're merging object literal values + if ( deep && copy && jQuery.isObjectLiteral(copy) ) { + // Don't extend not object literals + var clone = src && jQuery.isObjectLiteral(src) ? src : {}; // Never move original objects, clone them target[ name ] = jQuery.extend( deep, clone, copy ); @@ -323,18 +314,25 @@ jQuery.extend({ return toString.call(obj) === "[object Array]"; }, - isObject: function( obj ) { - if ( toString.call(obj) !== "[object Object]" ) { + isObjectLiteral: function( obj ) { + if ( toString.call(obj) !== "[object Object]" || typeof obj.nodeType === "number" ) { + return false; + } + + // not own constructor property must be Object + if ( obj.constructor + && !hasOwnProperty.call(obj, "constructor") + && !hasOwnProperty.call(obj.constructor.prototype, "isPrototypeOf") ) { return false; } //own properties are iterated firstly, //so to speed up, we can test last one if it is own or not - + var key; for ( key in obj ) {} - return !key || hasOwnProperty.call( obj, key ); + return key === undefined || hasOwnProperty.call( obj, key ); }, isEmptyObject: function( obj ) { @@ -421,19 +419,16 @@ jQuery.extend({ return (text || "").replace( rtrim, "" ); }, - makeArray: function( array ) { - var ret = [], i; + // results is for internal usage only + makeArray: function( array, results ) { + var ret = results || []; if ( array != null ) { - i = array.length; - // The window, strings (and functions) also have 'length' - if ( i == null || typeof array === "string" || jQuery.isFunction(array) || array.setInterval ) { - ret[0] = array; + if ( array.length == null || typeof array === "string" || jQuery.isFunction(array) || array.setInterval ) { + push.call( ret, array ); } else { - while ( i ) { - ret[--i] = array[i]; - } + jQuery.merge( ret, array ); } } @@ -441,6 +436,10 @@ jQuery.extend({ }, inArray: function( elem, array ) { + if ( array.indexOf ) { + return array.indexOf( elem ); + } + for ( var i = 0, length = array.length; i < length; i++ ) { if ( array[ i ] === elem ) { return i; @@ -451,12 +450,21 @@ jQuery.extend({ }, merge: function( first, second ) { - // We have to loop this way because IE & Opera overwrite the length - // expando of getElementsByTagName - var i = 0, elem, pos = first.length; + var pos, i = second.length; - while ( (elem = second[ i++ ]) != null ) { - first[ pos++ ] = elem; + // We have to get length this way when IE & Opera overwrite the length + // expando of getElementsByTagName + if ( i && i.nodeType ) { + for ( i = 0; second[i]; ++i ) {} + } + + pos = i + first.length; + + // Correct length for non Arrays + first.length = pos; + + while ( i ) { + first[ --pos ] = second[ --i ]; } return first;