aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjeresig <jeresig@gmail.com>2010-10-10 15:36:02 -0400
committerjeresig <jeresig@gmail.com>2010-10-10 15:36:02 -0400
commitba149e78a93afa9eab544c7defe3ccf0d412345a (patch)
tree7bb030658e820f07cb13376f5f76b4e715a89b65
parenteb67d9941694d39a592228bc6da71def3e619b94 (diff)
downloadjquery-ba149e78a93afa9eab544c7defe3ccf0d412345a.tar.gz
jquery-ba149e78a93afa9eab544c7defe3ccf0d412345a.zip
Switch back to using Sizzle.matchesSelector.
-rw-r--r--speed/filter.html4
-rw-r--r--src/traversing.js13
2 files changed, 9 insertions, 8 deletions
diff --git a/speed/filter.html b/speed/filter.html
index f24ed7d94..43ee94e52 100644
--- a/speed/filter.html
+++ b/speed/filter.html
@@ -14,8 +14,8 @@
setTimeout(function(){
name = "filter '" + item + "'";
jQuery("#results").append("<li>" + name + "<ul>" +
- "<li>new: " + benchmarkString("$('div').filter('" + item + "')", 1000, name) + "</li>" +
- "<li>old: " + benchmarkString("old('div').filter('" + item + "')", 1000, name) + "</li>" +
+ "<li>new: " + benchmarkString("$('div').filter('" + item + "')", 100, name) + "</li>" +
+ "<li>old: " + benchmarkString("old('div').filter('" + item + "')", 100, name) + "</li>" +
"</ul></li>");
jQuery("#results").append("<li>single " + name + "<ul>" +
"<li>new: " + benchmarkString("$('#nonexistant').filter('" + item + "')", 1000, name) + "</li>" +
diff --git a/src/traversing.js b/src/traversing.js
index df431781a..c473c7583 100644
--- a/src/traversing.js
+++ b/src/traversing.js
@@ -6,9 +6,8 @@ var runtil = /Until$/,
rmultiselector = /,/,
rchild = /^\s*>/,
isSimple = /^.[^:#\[\.,]*$/,
- slice = Array.prototype.slice;
-
-var POS = jQuery.expr.match.POS;
+ slice = Array.prototype.slice,
+ POS = jQuery.expr.match.POS;
jQuery.fn.extend({
find: function( selector ) {
@@ -100,13 +99,13 @@ jQuery.fn.extend({
var pos = POS.test( selectors ) ?
jQuery( selectors, context || this.context ) : null;
- var ret = [];
+ ret = [];
for ( var i = 0, j = this.length; i < j; i++ ) {
var cur = this[i];
while ( cur ) {
- if ( pos ? pos.index(cur) > -1 : jQuery.find.matches(selectors, cur) ) {
+ if ( pos ? pos.index(cur) > -1 : jQuery.find.matchesSelector(cur, selectors) ) {
ret.push( cur );
break;
@@ -229,7 +228,9 @@ jQuery.extend({
expr = ":not(" + expr + ")";
}
- return jQuery.find.matches(expr, elems);
+ return elems.length === 1 ?
+ jQuery.find.matchesSelector(elems[0], expr) ? [ elems[0] ] : [] :
+ jQuery.find.matches(expr, elems);
},
dir: function( elem, dir, until ) {