X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=src%2Ftraversing.js;h=dff10875462c803779a026fbd286575d982a01df;hb=cf672a2e7a886cac5ae62f6772c6b4b43b19a2fc;hp=583726b106524123492910b0131e26788c707094;hpb=a2bd8a53f3a750606abea9bbb6ee2302437d42f3;p=jquery.git diff --git a/src/traversing.js b/src/traversing.js index 583726b..dff1087 100644 --- a/src/traversing.js +++ b/src/traversing.js @@ -1,3 +1,5 @@ +(function( jQuery ) { + var runtil = /Until$/, rparentsprev = /^(?:parents|prevUntil|prevAll)/, // Note: This RegExp should be improved, or likely pulled from Sizzle @@ -54,9 +56,11 @@ jQuery.fn.extend({ closest: function( selectors, context ) { var ret; + if ( jQuery.isArray( selectors ) ) { var cur = this[0], match, matches = {}, selector, level = 1; ret = []; + if ( cur && selectors.length ) { for ( var i = 0, l = selectors.length; i < l; i++ ) { selector = selectors[i]; @@ -76,23 +80,27 @@ jQuery.fn.extend({ ret.push({ selector: selector, elem: cur, level: level }); } } + cur = cur.parentNode; level++; } } - return ret.length > 1 ? jQuery.unique(ret) : ret; + return ret; } var pos = jQuery.expr.match.POS.test( selectors ) ? jQuery( selectors, context || this.context ) : null; + ret = jQuery.map(this.get(),function( cur,i ) { while ( cur && cur.ownerDocument && cur !== context ) { if ( pos ? pos.index(cur) > -1 : jQuery(cur).is(selectors) ) { return cur; } + cur = cur.parentNode; } + return null; }); @@ -275,3 +283,5 @@ function winnow( elements, qualifier, keep ) { return (jQuery.inArray( elem, qualifier ) >= 0) === keep; }); } + +})( jQuery );