Today, I found a interesting difference between padding and margin when I’m working on Metrics 2.0 Introduction page. There are several VideoThumbnail
widget on the page, which contains a video snapshot and a paragraph text description.
Here is the Html DOM of the widget, written in Haml:
|
|
Since the description could be very short or very long, so I make the div that contains the description scrollable, so I wrote the following stylesheet for caption div:
|
|
The style looks fine, and here is how it looks:
data:image/s3,"s3://crabby-images/8e021/8e0210a3ad64f3617565a8dce1298dd24e518c18" alt="Wiget Wiget"
But very soon, I found the widget with scrollbar is taller than the one without it, it is because padding on 2 elements next to each other will not be merged: Red rect in following snapshot
data:image/s3,"s3://crabby-images/4a44c/4a44c5dc40668fb209ff6a9a6d0469d775347f9d" alt="Padding Padding"
It is caused because padding will not merged together as margin does, To solve the issue, I changed the padding to margin in the stylesheet:
|
|
But bottom margin is corrected, but I found the scrollbar begin to occupy the space of content, which is not good! The center widget uses padding(Blue) and the right one uses margin(Red)
data:image/s3,"s3://crabby-images/f8f3f/f8f3fb7520764029c169ccb3562295d52fa46ddc" alt="Margin Margin"
And I remember if I uses padding, the scrollbar takes the space of right padding; but if I use margin, it takes the space of the content. So I update the stylesheet in this way:
|
|
data:image/s3,"s3://crabby-images/b14e5/b14e55f061e21d96c21bb657fc46a959cf88ac76" alt="Padding Margin Mixing Padding Margin Mixing"
I use padding on the right but uses margin on other side, so vertical scrollbar will take the right padding when necessary. It is a very interesting CSS trick, and it works fine under webkit based browser.