aboutsummaryrefslogtreecommitdiffstats
path: root/src/offset.js
diff options
context:
space:
mode:
authorBrandon Aaron <brandon.aaron@gmail.com>2009-07-17 21:08:13 +0000
committerBrandon Aaron <brandon.aaron@gmail.com>2009-07-17 21:08:13 +0000
commit4edbff9fc13d49eb0c887be8c58c8e66dceb4c5c (patch)
tree2ea42f5e048da281b4d2df46bc47af768afbc3f5 /src/offset.js
parent1a7f72e7fe96654838074f88c79e021d37c5c30a (diff)
downloadjquery-4edbff9fc13d49eb0c887be8c58c8e66dceb4c5c.tar.gz
jquery-4edbff9fc13d49eb0c887be8c58c8e66dceb4c5c.zip
fix for #4906
Diffstat (limited to 'src/offset.js')
-rw-r--r--src/offset.js31
1 files changed, 17 insertions, 14 deletions
diff --git a/src/offset.js b/src/offset.js
index 0a8b9e64f..6b52b6ffb 100644
--- a/src/offset.js
+++ b/src/offset.js
@@ -75,7 +75,7 @@ jQuery.offset = {
body.removeChild( container );
jQuery.offset.initialize = function(){};
-
+
body = container = innerDiv = checkDiv = table = td = null;
},
@@ -135,32 +135,35 @@ jQuery.each( ['Left', 'Top'], function(i, name) {
jQuery.fn[ method ] = function(val) {
if ( !this[0] ) return null;
-
- var elem = this[0], win = ("scrollTo" in elem && elem.document) ? elem :
- (elem.nodeName === "#document") ? elem.defaultView || elem.parentWindow :
- false;
-
- return val !== undefined ?
+ if ( val !== undefined ) {
// Set the scroll offset
- this.each(function() {
- win = ("scrollTo" in this && this.document) ? this :
- (this.nodeName === "#document") ? this.defaultView || this.parentWindow :
- false;
-
+ return this.each(function() {
+ win = getWindow( this );
+
win ?
win.scrollTo(
!i ? val : jQuery(win).scrollLeft(),
i ? val : jQuery(win).scrollTop()
) :
this[ method ] = val;
- }) :
+ });
+ } else {
+ var elem = this[0],
+ win = getWindow( elem );
// Return the scroll offset
- win ?
+ return win && 'pageXOffset' in win ?
win[ i ? 'pageYOffset' : 'pageXOffset' ] ||
jQuery.support.boxModel && win.document.documentElement[ method ] ||
win.document.body[ method ] :
elem[ method ];
+ }
};
+
+ function getWindow( elem ) {
+ return ("scrollTo" in elem && elem.document) ? elem :
+ (elem.nodeName === "#document") ? elem.defaultView || elem.parentWindow :
+ false;
+ }
});