X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=src%2Ftraversing.js;h=67760450f300d60c876f556615ff73151a89ff4a;hb=a33d01a7b09f2b3b06ba273b89b77fec8d20b144;hp=a99dfdf1c7b157a0ac8ce3e2c7a7db8f7bee7eae;hpb=55a64cf095b295d334010c6e0a00863f307caffa;p=jquery.git diff --git a/src/traversing.js b/src/traversing.js index a99dfdf..6776045 100644 --- a/src/traversing.js +++ b/src/traversing.js @@ -1,14 +1,14 @@ var runtil = /Until$/, rparentsprev = /^(?:parents|prevUntil|prevAll)/, // Note: This RegExp should be improved, or likely pulled from Sizzle - rmultiselector = /,/, - slice = Array.prototype.slice; + rmultiselector = /,/; // Implement the identical functionality for filter and not var winnow = function( elements, qualifier, keep ) { if ( jQuery.isFunction( qualifier ) ) { return jQuery.grep(elements, function( elem, i ) { - return !!qualifier.call( elem, i, elem ) === keep; + var retVal = !!qualifier.call( elem, i, elem ); + return retVal === keep; }); } else if ( qualifier.nodeType ) { @@ -82,7 +82,7 @@ jQuery.fn.extend({ closest: function( selectors, context ) { if ( jQuery.isArray( selectors ) ) { - var ret = [], cur = this[0], match, matches = {}, selector; + var ret = [], cur = this[0], match, matches = {}, selector, level = 1; if ( cur && selectors.length ) { for ( var i = 0, l = selectors.length; i < l; i++ ) { @@ -100,11 +100,11 @@ jQuery.fn.extend({ match = matches[selector]; if ( match.jquery ? match.index(cur) > -1 : jQuery(cur).is(match) ) { - ret.push({ selector: selector, elem: cur }); - delete matches[selector]; + ret.push({ selector: selector, elem: cur, level: level }); } } cur = cur.parentNode; + level++; } }