X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=src%2Fcore.js;h=addff6bde760d48b93867cd265474229b22b54d6;hb=4b55e94d0849568a2fd121952f13a9d6571c731f;hp=b1dde53a0166a5128aaec0555d300fca137beb3b;hpb=d1285504fb636a077ae5b1e53e35959cc7faebc7;p=jquery.git diff --git a/src/core.js b/src/core.js index b1dde53..addff6b 100644 --- a/src/core.js +++ b/src/core.js @@ -39,6 +39,7 @@ var jQuery = function( selector, context ) { // Save a reference to some core methods toString = Object.prototype.toString, + hasOwnProperty = Object.prototype.hasOwnProperty, push = Array.prototype.push, slice = Array.prototype.slice, indexOf = Array.prototype.indexOf; @@ -52,11 +53,6 @@ jQuery.fn = jQuery.prototype = { return this; } - // $("body"): Shortcut for quickly finding the body element - if ( selector === "body" && !context && document.body ) { - selector = document.body; - } - // Handle $(DOMElement) if ( selector.nodeType ) { this.context = this[0] = selector; @@ -227,7 +223,7 @@ jQuery.fn = jQuery.prototype = { }, is: function( selector ) { - return !!selector && jQuery.multiFilter( selector, this ).length > 0; + return !!selector && jQuery.filter( selector, this ).length > 0; }, // For internal use only. @@ -284,7 +280,7 @@ jQuery.extend = jQuery.fn.extend = function() { clone = src; } else if ( jQuery.isArray(copy) ) { clone = []; - } else if ( jQuery.isObject(copy) ) { + } else if ( jQuery.isObjectLiteral(copy) ) { clone = {}; } else { clone = copy; @@ -327,8 +323,18 @@ jQuery.extend({ return toString.call(obj) === "[object Array]"; }, - isObject: function( obj ) { - return this.constructor.call(obj) === Object; + isObjectLiteral: function( obj ) { + if ( toString.call(obj) !== "[object Object]" ) { + 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 ); }, isEmptyObject: function( obj ) { @@ -449,43 +455,13 @@ jQuery.extend({ // expando of getElementsByTagName var i = 0, elem, pos = first.length; - // Also, we need to make sure that the correct elements are being returned - // (IE returns comment nodes in a '*' query) - if ( !jQuery.support.getAll ) { - while ( (elem = second[ i++ ]) != null ) { - if ( elem.nodeType !== 8 ) { - first[ pos++ ] = elem; - } - } - - } else { - while ( (elem = second[ i++ ]) != null ) { - first[ pos++ ] = elem; - } + while ( (elem = second[ i++ ]) != null ) { + first[ pos++ ] = elem; } return first; }, - unique: function( array ) { - var ret = [], done = {}, id; - - try { - for ( var i = 0, length = array.length; i < length; i++ ) { - id = jQuery.data( array[ i ] ); - - if ( !done[ id ] ) { - done[ id ] = true; - ret.push( array[ i ] ); - } - } - } catch( e ) { - ret = array; - } - - return ret; - }, - grep: function( elems, callback, inv ) { var ret = []; @@ -553,9 +529,12 @@ function evalScript( i, elem ) { } } +// Mutifunctional method to get and set values to a collection +// The value/s can be optionally by executed if its a function function access( elems, key, value, exec, fn ) { var l = elems.length; + // Setting many attributes if ( typeof key === "object" ) { for (var k in key) { access(elems, k, key[k], exec, fn); @@ -563,7 +542,9 @@ function access( elems, key, value, exec, fn ) { return elems; } + // Setting one attribute if (value !== undefined) { + // Optionally, function values get executed if exec is true exec = exec && jQuery.isFunction(value); for (var i = 0; i < l; i++) { @@ -574,6 +555,7 @@ function access( elems, key, value, exec, fn ) { return elems; } + // Getting an attribute return l ? fn(elems[0], key) : null; }