Bug 192249
Summary: | WebKit mistakenly applies "overflow:hidden" to the table wrapper box (but should instead apply it to the inner table box) | ||
---|---|---|---|
Product: | WebKit | Reporter: | Daniel Holbert <dholbert> |
Component: | Tables | Assignee: | Nobody <webkit-unassigned> |
Status: | NEW | ||
Severity: | Normal | CC: | bfulgham, simon.fraser, webkit-bug-importer, zalan |
Priority: | P2 | Keywords: | InRadar |
Version: | Safari 12 | ||
Hardware: | Unspecified | ||
OS: | Unspecified |
Daniel Holbert
(Note: I filed this for Chrome as https://bugs.chromium.org/p/chromium/issues/detail?id=910725 . It affects Safari 12 as well, so I'm copypasting the bug report over here.)
STR:
(1) Load this fiddle: https://jsfiddle.net/eq65w10u/
What is the expected result?
The higher up text *should not* be clipped (it should escape the yellow area).
The lower down text *should* be clipped to the pink area.
What happens instead?
The exact opposite -- the higher up text gets clipped, and the lower down text does not get clipped.
Safari's behavior indicates that it's applying "overflow:hidden" to the table wrapper box (it's performing its clipping at the level of that outer box, which is the box that encompasses the yellow caption and the pink table here).
And that is wrong, per CSS 2 section 17.4:
=====
The computed values of properties 'position', 'float', 'margin-*', 'top', 'right', 'bottom', and 'left' on the table element are used on the table wrapper box and not the table grid box; all other values of non-inheritable properties are used on the table grid box and not the table wrapper box. (Where the table element's values are not used on the table and table wrapper boxes, the initial values are used instead.)
=====
https://drafts.csswg.org/css2/tables.html#model
Note that this spec text says that "position" *does* apply to the wrapper box, but "overflow" is not among the specially listed properties there, so it should apply to the table grid box (the lower pink box here) -- that's the box whose boundaries we should be using for clipping. (And the abspos higher-up text shouldn't be clipped, because its abspos CB is the wrapper which is an ancestor of the clipping table-box.)
See also https://bugzilla.mozilla.org/show_bug.cgi?id=1232055 where this was (incorrectly) reported as a Firefox bug.
Firefox Nightly and Edge Insider Preview give "expected results" here.
Chrome 72 and Safari 12 give the buggy "actual results".
Note that this incompatibility caused a real-world webcompat bug, where a site is mistakenly depending on the Chrome/Safari behavior: https://github.com/webcompat/web-bugs/issues/21298
Attachments | ||
---|---|---|
Add attachment proposed patch, testcase, etc. |
Brent Fulgham
WebKit continues to match Chrome behavior here.
Radar WebKit Bug Importer
<rdar://problem/96320197>