X-Git-Url: http://git.asbjorn.it/?a=blobdiff_plain;f=src%2Ftraversing.js;h=a99dfdf1c7b157a0ac8ce3e2c7a7db8f7bee7eae;hb=c1ac9fdf45632f0e0d1f7183500ce45dde7319d7;hp=a09ae19377348ad808283a85a6d78e5ffb9fd795;hpb=61e37d41490aed319a176c6ca7feb95e5505059c;p=jquery.git diff --git a/src/traversing.js b/src/traversing.js index a09ae19..a99dfdf 100644 --- a/src/traversing.js +++ b/src/traversing.js @@ -24,7 +24,7 @@ var winnow = function( elements, qualifier, keep ) { if ( isSimple.test( qualifier ) ) { return jQuery.filter(qualifier, filtered, !keep); } else { - qualifier = jQuery.filter( qualifier, elements ); + qualifier = jQuery.filter( qualifier, filtered ); } } @@ -146,9 +146,9 @@ jQuery.fn.extend({ jQuery.makeArray( selector ), all = jQuery.merge( this.get(), set ); - return this.pushStack( set[0] && (set[0].setInterval || set[0].nodeType === 9 || (set[0].parentNode && set[0].parentNode.nodeType !== 11)) ? - jQuery.unique( all ) : - all ); + return this.pushStack( isDisconnected( set[0] ) || isDisconnected( all[0] ) ? + all : + jQuery.unique( all ) ); }, andSelf: function() { @@ -156,6 +156,12 @@ jQuery.fn.extend({ } }); +// A painfully simple check to see if an element is disconnected +// from a document (should be improved, where feasible). +function isDisconnected( node ) { + return !node || !node.parentNode || node.parentNode.nodeType === 11; +} + jQuery.each({ parent: function( elem ) { var parent = elem.parentNode; @@ -229,7 +235,7 @@ jQuery.extend({ dir: function( elem, dir, until ) { var matched = [], cur = elem[dir]; - while ( cur && cur.nodeType !== 9 && (until === undefined || !jQuery( cur ).is( until )) ) { + while ( cur && cur.nodeType !== 9 && (until === undefined || cur.nodeType !== 1 || !jQuery( cur ).is( until )) ) { if ( cur.nodeType === 1 ) { matched.push( cur ); }