X-Git-Url: http://git.asbjorn.it/?a=blobdiff_plain;ds=inline;f=src%2Fcore.js;h=5fa944bc307f1472ab417afac3111fb05dcef5b8;hb=4ea4fad0902839c06c281b5de7b0aca29922b63d;hp=23b96442e961a929e01fd6f69a1a7eeb46817406;hpb=957cd6fb2a2b7b8cfe9ac6b3f2b3cc2bc8163449;p=jquery.git diff --git a/src/core.js b/src/core.js index 23b9644..5fa944b 100644 --- a/src/core.js +++ b/src/core.js @@ -31,23 +31,32 @@ var jQuery = function( selector, context ) { // Used for trimming whitespace rtrim = /^\s+|\s+$/g, + // Match a standalone tag + rsingleTag = /^<(\w+)\s*\/?>$/, + // Keep a UserAgent string for use with jQuery.browser userAgent = navigator.userAgent.toLowerCase(), // Save a reference to some core methods toString = Object.prototype.toString, push = Array.prototype.push, - slice = Array.prototype.slice; + slice = Array.prototype.slice, + indexOf = Array.prototype.indexOf; jQuery.fn = jQuery.prototype = { init: function( selector, context ) { - var match, elem, ret; + var match, elem, ret, doc; // Handle $(""), $(null), or $(undefined) if ( !selector ) { 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; @@ -65,7 +74,19 @@ jQuery.fn = jQuery.prototype = { // HANDLE: $(html) -> $(array) if ( match[1] ) { - selector = jQuery.clean( [ match[1] ], context ); + doc = (context ? context.ownerDocument || context : document); + + // If a single string is passed in and it's a single tag + // just do a createElement and skip the rest + ret = rsingleTag.exec( selector ); + + if ( ret ) { + selector = [ doc.createElement( ret[1] ) ]; + + } else { + ret = buildFragment( [ match[1] ], [ doc ] ); + selector = (ret.cacheable ? ret.fragment.cloneNode(true) : ret.fragment).childNodes; + } // HANDLE: $("#id") } else { @@ -88,6 +109,10 @@ jQuery.fn = jQuery.prototype = { return this; } + // HANDLE: $("TAG") + } else if ( !context && /^\w+$/.test( selector ) ) { + selector = document.getElementsByTagName( selector ); + // HANDLE: $(expr, $(...)) } else if ( !context || context.jquery ) { return (context || rootjQuery).find( selector ); @@ -316,7 +341,8 @@ jQuery.extend({ isXMLDoc: function( elem ) { // documentElement is verified for cases where it doesn't yet exist // (such as loading iframes in IE - #4833) - return ((elem ? elem.ownerDocument || elem : 0).documentElement || 0).nodeName !== "HTML"; + var documentElement = (elem ? elem.ownerDocument || elem : 0).documentElement; + return documentElement ? documentElement.nodeName !== "HTML" : false; }, // Evalulates a script in a global context @@ -501,6 +527,12 @@ jQuery.extend({ } }); +if ( indexOf ) { + jQuery.inArray = function( elem, array ) { + return indexOf.call( array, elem ); + }; +} + // All jQuery objects should point back to these rootjQuery = jQuery(document);