aboutsummaryrefslogtreecommitdiffstats
path: root/src/traversing.js
diff options
context:
space:
mode:
authorjeresig <jeresig@gmail.com>2009-12-02 19:05:51 -0500
committerjeresig <jeresig@gmail.com>2009-12-02 19:05:51 -0500
commite534a310c7e99c44d93855ad5865ad5e985039ba (patch)
tree46832f782b6ec16f5eabc0993479619939b70428 /src/traversing.js
parent62436f4b292aadfe5419f897d7b8504054ab1c8c (diff)
downloadjquery-e534a310c7e99c44d93855ad5865ad5e985039ba.tar.gz
jquery-e534a310c7e99c44d93855ad5865ad5e985039ba.zip
Added in the new .closest(Array) method, will be used to improve the performance of live filtering.
Diffstat (limited to 'src/traversing.js')
-rw-r--r--src/traversing.js40
1 files changed, 31 insertions, 9 deletions
diff --git a/src/traversing.js b/src/traversing.js
index b5a5a2dee..737efa429 100644
--- a/src/traversing.js
+++ b/src/traversing.js
@@ -54,21 +54,43 @@ jQuery.fn.extend({
return this.pushStack( winnow(this, selector, true), "filter", selector );
},
- closest: function( selector, context ) {
- var pos = jQuery.expr.match.POS.test( selector ) ?
- jQuery( selector, context || this.context ) : null;
+ closest: function( selectors, context ) {
+ if ( jQuery.isArray( selectors ) ) {
+ var ret = [], cur = this[0], selector;
+
+ if ( cur ) {
+ for ( var i = 0, l = selectors.length; i < l; i++ ) {
+ selectors[i] = jQuery.expr.match.POS.test( selector ) ?
+ jQuery( selector, context || this.context ) :
+ selectors[i];
+ }
+
+ while ( cur && cur.ownerDocument && cur !== context ) {
+ for ( var i = 0; i < selectors.length; i++ ) {
+ selector = selectors[i];
+ if ( selector.jquery ? selector.index(cur) > -1 : jQuery(cur).is(selector) ) {
+ selector = selector.selector || selector;
+ ret.push({ selector: selector, elem: cur });
+ selectors.splice(i--, 1);
+ }
+ }
+ cur = cur.parentNode;
+ }
+ }
+
+ return ret;
+ }
+
+ var pos = jQuery.expr.match.POS.test( selectors ) ?
+ jQuery( selectors, context || this.context ) : null;
- return this.map(function(){
- var cur = this, closer = 0;
+ return this.map(function(i, cur){
while ( cur && cur.ownerDocument && cur !== context ) {
- if ( pos ? pos.index(cur) > -1 : jQuery(cur).is(selector) ) {
- jQuery.lastCloser = closer;
+ if ( pos ? pos.index(cur) > -1 : jQuery(cur).is(selectors) ) {
return cur;
}
cur = cur.parentNode;
- closer++;
}
- jQuery.lastCloser = -1;
return null;
});
},