From: brandonaaron Date: Sun, 28 Feb 2010 01:43:23 +0000 (-0600) Subject: Use correct window reference in offset to work properly cross-frame. Fixes #6190. X-Git-Url: http://git.asbjorn.it/?a=commitdiff_plain;h=1d352084c4257217b0778f1ec3bb2e409411a4c3;p=jquery.git Use correct window reference in offset to work properly cross-frame. Fixes #6190. --- diff --git a/src/offset.js b/src/offset.js index f80574e..fbefd7a 100644 --- a/src/offset.js +++ b/src/offset.js @@ -16,10 +16,17 @@ if ( "getBoundingClientRect" in document.documentElement ) { return jQuery.offset.bodyOffset( elem ); } - var box = elem.getBoundingClientRect(), doc = elem.ownerDocument, body = doc.body, docElem = doc.documentElement, - clientTop = docElem.clientTop || body.clientTop || 0, clientLeft = docElem.clientLeft || body.clientLeft || 0, - top = box.top + (self.pageYOffset || jQuery.support.boxModel && docElem.scrollTop || body.scrollTop ) - clientTop, - left = box.left + (self.pageXOffset || jQuery.support.boxModel && docElem.scrollLeft || body.scrollLeft) - clientLeft; + var box = elem.getBoundingClientRect(), + doc = elem.ownerDocument, + body = doc.body, + docElem = doc.documentElement, + win = getWindow(doc), + clientTop = docElem.clientTop || body.clientTop || 0, + clientLeft = docElem.clientLeft || body.clientLeft || 0, + scrollTop = (win.pageYOffset || jQuery.support.boxModel && docElem.scrollTop || body.scrollTop ), + scrollLeft = (win.pageXOffset || jQuery.support.boxModel && docElem.scrollLeft || body.scrollLeft), + top = box.top + scrollTop - clientTop, + left = box.left + scrollLeft - clientLeft; return { top: top, left: left }; }; diff --git a/test/unit/offset.js b/test/unit/offset.js index dbaddc8..3d71ef1 100644 --- a/test/unit/offset.js +++ b/test/unit/offset.js @@ -1,5 +1,39 @@ module("offset"); +testoffset("absolute"/* in iframe */, function($, iframe) { + expect(4); + + var doc = iframe.document, tests; + + // force a scroll value on the main window + // this insures that the results will be wrong + // if the offset method is using the scroll offset + // of the parent window + var forceScroll = jQuery('
', { width: 2000, height: 2000 }).appendTo('body'); + window.scrollTo(1, 1); + + // get offset + tests = [ + { id: '#absolute-1', top: 1, left: 1 } + ]; + jQuery.each( tests, function() { + equals( jQuery( this.id, doc ).offset().top, this.top, "jQuery('" + this.id + "').offset().top" ); + equals( jQuery( this.id, doc ).offset().left, this.left, "jQuery('" + this.id + "').offset().left" ); + }); + + + // get position + tests = [ + { id: '#absolute-1', top: 0, left: 0 } + ]; + jQuery.each( tests, function() { + equals( jQuery( this.id, doc ).position().top, this.top, "jQuery('" + this.id + "').position().top" ); + equals( jQuery( this.id, doc ).position().left, this.left, "jQuery('" + this.id + "').position().left" ); + }); + + forceScroll.remove(); +}); + testoffset("absolute", function( jQuery ) { expect(144); @@ -306,8 +340,8 @@ testoffset("body", function( jQuery ) { }); test("Chaining offset(coords) returns jQuery object", function() { - expect(2); - var coords = { top: 1, left: 1 }; + expect(2); + var coords = { top: 1, left: 1 }; equals( jQuery("#absolute-1").offset(coords).selector, "#absolute-1", "offset(coords) returns jQuery object" ); equals( jQuery("#non-existent").offset(coords).selector, "#non-existent", "offset(coords) with empty jQuery set returns jQuery object" ); });