Skip to content

Commit

Permalink
Added support for .closest(filter, DOMElement). Fixes #4072.
Browse files Browse the repository at this point in the history
  • Loading branch information
jeresig committed Jul 28, 2009
1 parent 61b18c8 commit d6991fa
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 3 deletions.
4 changes: 2 additions & 2 deletions src/traversing.js
Expand Up @@ -51,13 +51,13 @@ jQuery.fn.extend({
return this.pushStack( jQuery.winnow(this, selector, true), "filter", selector );
},

closest: function( selector ) {
closest: function( selector, context ) {
var pos = jQuery.expr.match.POS.test( selector ) ? jQuery(selector) : null,
closer = 0;

return this.map(function(){
var cur = this;
while ( cur && cur.ownerDocument ) {
while ( cur && cur.ownerDocument && cur !== context ) {
if ( pos ? pos.index(cur) > -1 : jQuery(cur).is(selector) ) {
jQuery.data(cur, "closest", closer);
return cur;
Expand Down
8 changes: 7 additions & 1 deletion test/unit/traversing.js
Expand Up @@ -91,14 +91,20 @@ test("filter(jQuery)", function() {
})

test("closest()", function() {
expect(6);
expect(9);
isSet( jQuery("body").closest("body").get(), q("body"), "closest(body)" );
isSet( jQuery("body").closest("html").get(), q("html"), "closest(html)" );
isSet( jQuery("body").closest("div").get(), [], "closest(div)" );
isSet( jQuery("#main").closest("span,#html").get(), q("html"), "closest(span,#html)" );

isSet( jQuery("div:eq(1)").closest("div:first").get(), [], "closest(div:first)" );
isSet( jQuery("div").closest("body:first div:last").get(), q("fx-tests"), "closest(body:first div:last)" );

// Test .closest() limited by the context
var jq = jQuery("#nothiddendivchild");
isSet( jq.closest("html", document.body).get(), [], "Context limited." );
isSet( jq.closest("body", document.body).get(), [], "Context limited." );
isSet( jq.closest("#nothiddendiv", document.body).get(), q("nothiddendiv"), "Context not reached." );
});

test("not(Selector)", function() {
Expand Down

0 comments on commit d6991fa

Please sign in to comment.