WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
NEW
17309
Absolutely-positioned div with "overflow: visible auto" doesn't allow enough width for contents when scrollbar is present
https://bugs.webkit.org/show_bug.cgi?id=17309
Summary
Absolutely-positioned div with "overflow: visible auto" doesn't allow enough ...
Jonathan Hurshman
Reported
2008-02-11 06:56:43 PST
An absolutely-positioned div with overflow-x: visible and overflow-y: auto ought to permit its children to determine its width. In so doing, the width of the div's scrollbar needs to be accounted for, if it is visible. However, it appears that WebKit is not accounting for the scrollbar's width. It looks like it calculates its contents' height and width and sets its own width, then applies the scrollbar. This leads to the div being too narrow for the contents, which either causes the contents to wrap, or if the contents are "white-space: nowrap", causes the div to scroll horizontally as well as vertically.
Attachments
A reduction of the issue.
(1.15 KB, text/html)
2008-02-11 06:58 PST
,
Jonathan Hurshman
no flags
Details
View All
Add attachment
proposed patch, testcase, etc.
Jonathan Hurshman
Comment 1
2008-02-11 06:58:00 PST
Created
attachment 19066
[details]
A reduction of the issue. A reduction of the issue, showing one div with non-wrappable contents and another with wrappable.
Jonathan Hurshman
Comment 2
2008-02-13 13:29:08 PST
(In reply to
comment #0
)
> An absolutely-positioned div with overflow-x: visible and overflow-y: auto > ought to permit its children to determine its width.
I should have added that the div in question has no explicit width.
vituko
Comment 3
2010-01-14 13:39:08 PST
532.5 this bug is still there more exactly, it happens when the layer pushes the parent width Ok : -Absolute positioned layer -Layer width smaller than parent width Ko : -Layer with float left : always pushes -Layer width bigger than parent width : for example, when increasing the table cell default width Ok : <table style="width:200px"><tr><td> <div style="overflow-y:scroll ; overflow-x:visible">asdf</div> </td><td>asdf</td></tr></table> Ko : <table style="width:200px"><tr><td> <div style="overflow-y:scroll ; overflow-x:visible">asdf</div> </td><td style="width:100%">asdf</td></tr></table> <table><tr><td> <div style="overflow-y:scroll ; overflow-x:visible">asdf</div> </td><td>asdf</td></tr></table> Until the patch comes, possible workaround : overflow-x:hidden + padding-right (scroll width)
vituko
Comment 4
2010-01-15 00:10:13 PST
Sorry Until the patch comes, possible workaround : overflow-x:hidden + padding-right (scroll width) ... ... but the padding is seen in IE and Firefox, both work as expected. The behavior in Opera and Khtml is similar to Webkit. overflow-x:visible also becomes auto in Firefox, but the vertical scroll width is computed and the box pushes its container without showing the horizontal scroll nor hiding some content.
vituko
Comment 5
2010-01-15 00:13:20 PST
532.5 this bug is still there more exactly, it happens when the layer pushes the parent width Ok : -Absolute positioned layer -Layer width smaller than parent width Ko : -Layer with float left : always pushes -Layer width bigger than parent width : for example, when increasing the table cell default width Ok : <table style="width:200px"><tr><td> <div style="overflow-y:scroll ; overflow-x:visible">asdf</div> </td><td>asdf</td></tr></table> Ko : <table style="width:200px"><tr><td> <div style="overflow-y:scroll ; overflow-x:visible">asdf</div> </td><td style="width:100%">asdf</td></tr></table> <table><tr><td> <div style="overflow-y:scroll ; overflow-x:visible">asdf</div> </td><td>asdf</td></tr></table> Until the patch comes, possible workaround : overflow-x:hidden + padding-right (scroll width)
vituko
Comment 6
2010-01-15 00:25:32 PST
Sorry, I dont know if I should use a webkit browser, but I had technical problems to submit my comments.
nicolas roumiantzeff
Comment 7
2010-12-05 23:29:57 PST
The issue is not yet fixed in current version of webkit browsers. Tested on: - Safari 5.0.3 (7533.19.4) - Chrome 8.0.552.215 Our web application uses a scrollable div inside a table non-fixed width table. We currently use the workaround suggested in this log (thanks Vituko) but the problem is that the width of the scrollbars may vary from system to system (and perhaps resolution or settings).
Robert Hogan
Comment 8
2011-08-10 14:15:11 PDT
Unless I'm mistaken FF4 treats the reduced test case the same as WebKit now.
Ahmad Saleem
Comment 9
2023-02-16 13:27:06 PST
In attached test case, Safari 16.3 show horizontal scrollbar for first container similar to Firefox Nightly 112 while Chrome Canary 112 does not show horizontal scrollbar. Just wanted to share updated testing results. Thanks!
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug