我有一个包含另一个div(子)的div(父)。Parent是body中的第一个元素,没有特定的CSS样式。当我设置

.child
{
    margin-top: 10px;
}

最终的结果是我的子的顶部仍然与父对齐。我的父结点向下移动10px,而不是子结点向下移动10px。

我的DOCTYPE被设置为XHTML Transitional。

我错过了什么?

编辑1 我的父母需要有严格定义的尺寸,因为它有一个背景,必须显示在它下面从上到下(像素完美)。所以不能在上面设置垂直边距。

编辑2 这种行为在FF、IE和CR上都是一样的。


当前回答

这对我来说很管用

.parent {
padding-top: 1px;
margin-top: -1px;
}

.child {
margin-top:260px;
}

http://jsfiddle.net/97fzwuxh/

其他回答

父元素不能为空,至少要放 在子元素之前。

在DIVs内的子元素中找到了一个边距的替代方法,您还可以添加:

.parent { overflow: auto; }

or:

.parent { overflow: hidden; }

这可以防止边际崩溃。边框和填充也是如此。 因此,你也可以使用以下方法来防止最高利润崩溃:

.parent {
    padding-top: 1px;
    margin-top: -1px;
}

2021年更新:如果你愿意放弃IE11支持,你也可以使用新的CSS结构display: flow-root。有关块格式上下文的全部细节,请参阅MDN Web文档。


按大众要求更新: 缩边距的全部意义在于处理文本内容。例如:

H1, h2, p, ul { margin-top: 1 em; margin-bottom: 1 em; 轮廓:1px蓝色虚线; } Div{大纲:1px固体红色;} <标题>标题!< / h1 > < div class = " text " > < h2 >标题!< / h2 > < p > < / p >款 < / div > < div class = " text " > < h2 >标题!< / h2 > < p > < / p >款 < ul > <李>列表项李< / > < / ul > < / div >

由于浏览器折叠了页边距,因此文本将按照您所期望的方式显示,并且<div>包装器标记不会影响页边距。每个元素确保其周围有间距,但间距不会加倍。<h2>和<p>的裕度不会叠加,而是相互滑入(它们坍缩)。<p>和<ul>元素也是如此。

可悲的是,在现代设计中,当你明确地想要一个容器时,这个想法会让你感到不快。这在CSS中被称为新的块格式化上下文。溢出或边距技巧会给你这个。

为子元素添加样式显示:inline-block

你可以通过在伪元素display: flex;给父母。

.parent:before {
  content: '';
  display: flex;
}

另一种方法是将父节点的display属性设置为flow-root。

.parent {
  display: flow-root;
}

.child中包含的元素的边缘正在折叠。

<html>
<style type="text/css" media="screen">
    #parent {background:#dadada;}
    #child {background:red; margin-top:17px;}
</style>
<body>
<div id="parent">

    <p>&amp;</p>

    <div id="child">
        <p>&amp;</p>    
    </div>

</div>
</body>
</html>

在这个例子中,p从浏览器默认样式接收一个边距。浏览器默认的字体大小通常是16px。通过在#child上设置超过16px的顶部边距,你开始注意到它的位置移动。