父元素与子元素之间的margin-top问题(css hack)

html结构如下:

<div class="parents">
    <div class="son"></div>
</div>

css结构如下:

        .parents{
            height: 200px;
            width: 200px;
            background-color: gray;
        }
        .son{
            height: 100px;
            width: 100px;
            background-color: red;
            margin-top: 50px;
        }

效果如下:

父元素的位置会跟着子元素的margin-top值而变化

解决办法如下:
1.修改父元素的高度,增加padding-top样式模拟(padding-top:1px;常用)
2.为父元素添加overflow:hidden;样式即可(完美)
3.为父元素或者子元素声明浮动(float:left;可用)
4.为父元素添加border(border:1px solid transparent可用)
5.为父元素或者子元素声明绝对定位

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,806评论 1 92
  • 转载请声明 原文链接地址 关注公众号获取更多资讯 第一部分 HTML 第一章 职业规划和前景 职业方向规划定位...
    前端进阶之旅阅读 16,621评论 32 459
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    wzhiq896阅读 1,805评论 0 2
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    love2013阅读 2,337评论 0 11
  • 1、垂直对齐 如果你用CSS,则你会有困惑:我该怎么垂直对齐容器中的元素?现在,利用CSS3的Transform,...
    kiddings阅读 3,203评论 0 11