iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > html >如何深入剖析Firefox下margin-top失效原因与解决方案
  • 490
分享到

如何深入剖析Firefox下margin-top失效原因与解决方案

2024-04-02 19:04:59 490人浏览 泡泡鱼
摘要

这期内容当中小编将会给大家带来有关如何深入剖析Firefox下margin-top失效原因与解决方案,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。和大家重点讨论一下Fir

这期内容当中小编将会给大家带来有关如何深入剖析Firefox下margin-top失效原因与解决方案,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

和大家重点讨论一下Firefox margin-top失效的原因与解决办法,在这个说明中,“collapsingmargins”(折叠margin)的意思是:2个或以上盒模型之间相邻的margin属性结合表示为一个单独的margin。

Firefox margin-top失效的原因与解决办法

最近发现好多用margin-top实现的,上边距效果一直没有,一直都不知道什么原因,今天偶然看到了,特分享给大家。在这个说明中,“collapsingmargins”(折叠margin)的意思是:2个或以上盒模型之间(关系可以是相邻或嵌套)相邻的margin属性(这之间不能有非空内容、padding区域、border边框或使用清除分离方法)结合表示为一个单独的margin。
CSS2.1中,水平的margin不会被折叠。

垂直margin可能在一些盒模型中被折叠:

1、在常规文档流中,

2个或以上的块级盒模型相邻的垂直margin会被折叠。

最终的margin值计算方法如下:

a、全部都为正值,取***者;
b、不全是正值,则都取绝对值,然后用正值减去***值;
c、没有正值,则都取绝对值,然后用0减去***值。

注意:相邻的盒模型可能由DOM元素动态产生并没有相邻或继承关系。

2、相邻的和模型中,如果其中的一个是浮动的(floated),垂直margin不会被折叠,甚至一个浮动的盒模型和它的子元素之间也是这样。

3、设置了overflow属性的元素和它的子元素之间的margin不会被折叠(overflow取值为visible除外)。

4、设置了绝对定位(position:absolute)的盒模型,垂直margin不会被折叠,甚至和他们的子元素之间也是一样。

5、设置了display:inline-block的元素,垂直margin不会被折叠,甚至和他们的子元素之间也是一样。

6、如果一个盒模型的上下margin相邻,这时它的margin可能折叠覆盖(collapsethrough)它。在这种情况下,元素的位置(position)取决于它的相邻元素的margin是否被折叠。

a、如果元素的margin和它的父元素的margin-top折叠在一起,盒模型border-top的边界定义和它的父元素相同。
b、另外,任意元素的父元素不参与margin的折叠,或者说只有父元素的margin-bottom是参与计算的。如果元素的border-top非零,那么元素的border-top边界位置和原来一样。
一个应用了清除操作的元素的margin-top绝不会和它的块级父元素的margin-bottom折叠。

注意,那些已经被折叠覆盖的元素的位置对其他已经被折叠的元素的位置没有任何影响;只有在对这些元素的子元素布局时,border-top边界位置才是必需的。

7、根元素的垂直margin不会被折叠。

浮动的块级元素的margin-bottom总是与它后面的浮动块级兄弟元素(floatednextin-flowblock-levelsibling)的margin-top相邻,除非那个同级元素使用了清除操作。

浮动的块级元素的margin-top和它的***个浮动块级子元素(floatedfirstin-flowblock-levelchild)的margin-top相邻(如果该元素没有border-top,没有padding-top,并且子元素没有使用清除操作)。

浮动的块级元素的margin-bottom如果符合下列条件,那么它和它的***一个浮动块级子元素的margin-bottom相邻(如果该元素没有指定padding-bottom或border):
a、指定了height:auto
b、min-height小于元素的实际使用高度(height)
c、max-height大于元素的实际使用高度(height)

如果一个元素的min-height属性设置为0,那么它所拥有的margin是相邻的,并且它既没有border-top和border-bottom,也没有padding-top和padding-bottom,它的height属性可以是0或auto,它不能包含一个内联的盒模型(linebox),它所有的浮动子元素(如果有的话)的margin也都是相邻的。

当一个元素拥有的margin折叠了,并且它使用了清除操作,那么它的margin-top会和紧随其后的兄弟元素的相邻margin折叠,但结果是它的margin将无法和其块级父元素的margin-bottom折叠。
折叠操作是以padding、margin、border的值为基础的(即在浏览器解析所有这些值之后),折叠后的margin计算将覆盖已使用的不同margin的值。

代码如下:

<dividdivid="d0"style="background-color:#333333;height:500px;"> <brstylebrstyle="line-height:0;"/> //不加入br这一行,在Firefox中id1的margin-top:20px将会在d0上作用,使d0上方与body间有20px的间距,d1与d0的上方没有间距,  而IE内正常显示  <dividdivid="d1"style="background-color:#000000;margin-top:20px;height:100px;"></div> <dividdivid="d2"style="background-color:#000000;margin-top:20px;height:100px;"></div> </div>

上述就是小编为大家分享的如何深入剖析Firefox下margin-top失效原因与解决方案了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网html频道。

--结束END--

本文标题: 如何深入剖析Firefox下margin-top失效原因与解决方案

本文链接: https://www.lsjlt.com/news/86606.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何深入剖析Firefox下margin-top失效原因与解决方案
    这期内容当中小编将会给大家带来有关如何深入剖析Firefox下margin-top失效原因与解决方案,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。和大家重点讨论一下Fir...
    99+
    2024-04-02
  • 粘性定位的失效原因及解决方案深入分析
    粘性定位为何会失去效果?探讨原因与解决方案 引言:在现代网页设计中,粘性定位(Sticky Positioning)被广泛应用于提升用户的交互体验。它可以使元素在滚动过程中“粘”在页面的某个位置,起到固定的效果。然而,在某些情况...
    99+
    2024-01-29
    定位:粘性 失效原因:原因 解决方案:方案
  • 如何解决CSS margin-top在火狐下失效问题
    这期内容当中小编将会给大家带来有关如何解决CSS margin-top在火狐下失效问题,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。margin-top属性在火狐及IE下...
    99+
    2024-04-02
  • Discuz验证失败的原因分析与解决方案
    Discuz验证失败的原因分析与解决方案 在Discuz使用过程中,用户可能会遇到各种验证失败的问题,如登录失败、权限不足等。本文将针对这些问题进行分析,并提出解决方案,同时给出具体的...
    99+
    2024-03-11
    原因: 网络问题
  • 阿里云应用服务器购买失败原因分析与解决方案
    本文将针对阿里云应用服务器购买失败的问题,进行深入分析,并提供有效的解决方案。阿里云作为全球领先的云计算服务提供商,其应用服务器是许多企业和开发者的选择,然而,购买过程中可能会遇到一些问题,如购买失败。本文将详细解析购买失败的原因,并提供相...
    99+
    2023-10-30
    阿里 解决方案 原因
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作