HTML边距推送其他元素

前端之家收集整理的这篇文章主要介绍了HTML边距推送其他元素前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
有人可以回答我,为什么当我设置一个margin-top到我的< div id =“logo”>时,所有其他div都会被推下来.为什么如果设置浮动:离开我的< div id =“logo”>,一切正常.

码:

@H_502_4@<!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的段落:

@H_502_4@p { margin: 1em 0; }

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

浮动修复

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

修复

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

原文链接:https://www.f2er.com/html/242693.html

猜你在找的HTML相关文章