加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 资源网站 > 资源 > 正文

HTML边距推送其他元素

发布时间:2020-12-14 19:45:13 所属栏目:资源 来源:网络整理
导读:有人可以回答我,为什么当我设置一个margin-top到我的 div id =“logo”时,所有其他div都会被推下来.为什么如果设置浮动:离开我的 div id =“logo”,一切正常. 码: !DOCTYPE htmlhtml lang="pt-br" head titleOlá Mundo!/title style /* CSS RESET HERE */
有人可以回答我,为什么当我设置一个margin-top到我的< div id =“logo”>时,所有其他div都会被推下来.为什么如果设置浮动:离开我的< div id =“logo”>,一切正常.

码:

<!DOCTYPE html>
<html lang="pt-br">
  <head>
    <title>Olá Mundo!</title>
    <style>
      /* CSS RESET HERE */ ( http://html5doctor.com/html-5-reset-stylesheet/ )
      body { margin:0; }
      #container { width:1000px; min-height:100%; height:auto; margin:0 auto; }
      #header { width:100%; height:160px; background-color:#FF0; }
      #logo { width:150px; height:150px; margin:10px 0 0 10px; background-color:#F0F; }
    </style>
  </head>
  <body>

    <div id="container">
      <div id="header">

        <div id="logo">
          <h1>Minha logo!</h1>
          <h2>meu slogan ...</h2>
        </div>

      </div>

  </body>  
</html>

解决方法

它是由 margin collapse引起的.

正常文件流程

在< div id =“logo”>的情况下没有漂浮,它的上边缘实际上是从其包含元素的顶部伸出,这将一切都推下来.这种行为的原因(正如上面的文章指出的那样)是这样的,如果你有一系列带有以下CSS的段落:

p {
   margin: 1em 0;
}

它们之间只有1em的边距,而不是2em(如果边距没有崩溃,这将是结果).

浮动修复

当你浮动< div id =“logo”>它将其从正常的文档流程中取出,这意味着它的上边距不再与其父级边距折叠.

修复

在您的情况下修复边距折叠的其他选项是向您的< div id =“header”>添加1px的顶部/底部填充或边框.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读