X-Git-Url: http://git.asbjorn.biz/?p=jquery.git;a=blobdiff_plain;f=src%2Ftraversing.js;h=1633e2e162d6fea779ef680355a2edd0d22a618b;hp=f57819d86d399016b71fbebb8fd2dddb7c9c77c7;hb=0ca35de311ff4d1dac5c9dc4de05a32a1754cd7a;hpb=cbf9d874e52212d0289deae747066eccfebde770 diff --git a/src/traversing.js b/src/traversing.js index f57819d..1633e2e 100644 --- a/src/traversing.js +++ b/src/traversing.js @@ -8,6 +8,8 @@ var runtil = /Until$/, isSimple = /^.[^:#\[\.,]*$/, slice = Array.prototype.slice; +var POS = jQuery.expr.match.POS; + jQuery.fn.extend({ find: function( selector ) { // Handle "> div" child selectors and pass them to .children() @@ -95,21 +97,27 @@ jQuery.fn.extend({ return ret; } - var pos = jQuery.expr.match.POS.test( selectors ) ? + var pos = 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; - } + var ret = []; - cur = cur.parentNode; - } + for ( var i=0,j=this.length; i -1 : jQuery.find.matches(selectors, [cur]).length ) { + ret.push( cur ); + break; + } else { + cur = cur.parentNode; + if ( !cur.ownerDocument || cur === context ) { + break; + } + } + } + } - return null; - }); - ret = ret.length > 1 ? jQuery.unique(ret) : ret; return this.pushStack( ret, "closest", selectors );