Closed Bug 253135 Opened 21 years ago Closed 21 years ago

The Bottom attribute for Absolutely positioned elements is calculated relative to the window, not the page

Categories

(Core :: CSS Parsing and Computation, defect)

defect
Not set
trivial

Tracking

()

RESOLVED DUPLICATE of bug 105286

People

(Reporter: r.s.goldsmith, Assigned: dbaron)

References

()

Details

Attachments

(2 files)

User-Agent: Mozilla/5.0 (Macintosh; U; PPC Mac OS X; en-us) AppleWebKit/125.2 (KHTML, like Gecko) Safari/125.8 Build Identifier: At the site 'www.far-blue.co.uk' the semi-translucent grey box is an absolutely positioned div with a 'bottom' attribute set to 20px above the bottom of the page. This seems to render correctly in khtml based browsers but Mozilla based browsers calculate this offset from the bottom relative to the original window size for the browser (or seem to). As a result, if the div's content is larger than 1 window height, it will overflow and a vertical scroll bar will appear but the grey div does no get recalculated. Reproducible: Always Steps to Reproduce: 1. Visit www.far-blue.co.uk or, even better, one of the longer pages such as Thoughts-Reasoning Love 2. if needed, resize the browser window so that the content is too deep for the window 3. Actual Results: The content overflows the grey parent element, which has been calculated based on window or initial page height, not final page height. Expected Results: The grey parent element should have grown to accommodate the content and still leave 20px at the bottom of the page as specified in the css. You can see what I consider the correct rendering in, for instance, Safari
the grey box looks exactly the same to me in konqueror and mozilla (linux, but you marked this all platforms). can you attach a screenshot of the misrendering? and of how you expect it to look?
compare this to the other image, which is from Safari, and look carefully at the grey background. In Safari it comes right down to the bottom of the page, in Mozilla, it stops just above the line starting 'Love is essential'
compare this to the other image, which is from Mozilla, and look carefully at the grey background. In Safari it comes right down to the bottom of the page, in Mozilla, it stops just above the line starting 'Love is essential'
The 20px should be measured from the bottom of the containing block. Since there are no positioned ancestors, the containing block for the body is the initial containing block in CSS2.1 (unlike CSS2.0, where it was the root element). The initial containing block in Mozilla is the viewport, so the rendering is correct. It sounds like the version of khtml you are using is rendering per CSS 2.0... Please report this to them as a bug.
Status: UNCONFIRMED → RESOLVED
Closed: 21 years ago
Resolution: --- → INVALID
so you are saying that the root container is no longer the page? So from now on, anyone wishing to specify css values relative to the page will have to explicitly code a page-sized root container? And is it even possible to do this now? No, that doesn't sound right. The CSS spec only -suggests- the initial cb is based on the view port but this behaviour allows an otherwise correctly coded div to allow it's content to overspill. I would expect this behaviour from a fixed element (as I expect a fixed element's attributes to refer to the viewport, as the css spec requires) but not of an absolute element where I would always expect the attributes to refer to the page.
Isn't this a dupe of bug 105286?
> so you are saying that the root container is no longer the page? There is no "the page" in CSS... The initial containing block is indeed distinct from the box established by the root element in CSS 2.1. Note that setting the root element to position:relative makes it the containing block for its positioned descendants, though. > Isn't this a dupe of bug 105286? You're right. It is.
Status: RESOLVED → UNCONFIRMED
Resolution: INVALID → ---
*** This bug has been marked as a duplicate of 105286 ***
Status: UNCONFIRMED → RESOLVED
Closed: 21 years ago21 years ago
Resolution: --- → DUPLICATE
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Created:
Updated:
Size: