aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohn Resig <jeresig@gmail.com>2009-02-17 17:51:50 +0000
committerJohn Resig <jeresig@gmail.com>2009-02-17 17:51:50 +0000
commitd8b3bd700fe131d8b1dc381163abc6386a90501e (patch)
tree2bae8bf4404cf3319ba0b9c1584fa334236f6d68
parent4b7e1c906f497784329622d82da08c8646cae7e6 (diff)
downloadjquery-d8b3bd700fe131d8b1dc381163abc6386a90501e.tar.gz
jquery-d8b3bd700fe131d8b1dc381163abc6386a90501e.zip
Switch to using createRange for element comparision instead of Array indexOf checks - thanks for the tip, Ioseb.
-rw-r--r--src/selector.js16
1 files changed, 9 insertions, 7 deletions
diff --git a/src/selector.js b/src/selector.js
index 6538d9706..3e1d7115d 100644
--- a/src/selector.js
+++ b/src/selector.js
@@ -692,20 +692,22 @@ if ( document.documentElement.compareDocumentPosition ) {
}
return ret;
};
-} else if ( Array.prototype.indexOf ) {
- var indexOf = Array.prototype.indexOf,
- allSort = document.getElementsByTagName("*");
-
+} else if ( "sourceIndex" in document.documentElement ) {
sortOrder = function( a, b ) {
- var ret = indexOf.call( allSort, a ) - indexOf.call( allSort, b );
+ var ret = a.sourceIndex - b.sourceIndex;
if ( ret === 0 ) {
hasDuplicate = true;
}
return ret;
};
-} else if ( "sourceIndex" in document.documentElement ) {
+} else if ( document.createRange ) {
sortOrder = function( a, b ) {
- var ret = a.sourceIndex - b.sourceIndex;
+ var aRange = a.ownerDocument.createRange(), bRange = b.ownerDocument.createRange();
+ aRange.selectNode(a);
+ aRange.collapse(true);
+ bRange.selectNode(b);
+ bRange.collapse(true);
+ var ret = aRange.compareBoundaryPoints(Range.START_TO_END, bRange);
if ( ret === 0 ) {
hasDuplicate = true;
}