千家信息网

margin-top在Firefox失效怎么办

发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,这篇文章主要介绍margin-top在Firefox失效怎么办,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!margin-top在Firefox失效的解决方法"collapsi
千家信息网最后更新 2025年01月19日margin-top在Firefox失效怎么办

这篇文章主要介绍margin-top在Firefox失效怎么办,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

margin-top在Firefox失效的解决方法

"collapsingmargins"(折叠margin)的意思是:2个或以上盒模型之间(关系可以是相邻或嵌套)相邻的margin属性(这之间不能有非空内容、padding区域、border边框或使用清除分离方法)结合表示为一个单独的margin。在css2.1中,水平的margin不会被折叠。

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

1.在常规文档流中,2个或以上的块级盒模型相邻的垂直margin会被折叠。最终的margin值计算方法如下:

◆全部都为正值,取***者;

◆不全是正值,则都取绝对值,然后用正值减去***值;

◆没有正值,则都取绝对值,然后用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是否被折叠。
如果元素的margin和它的父元素的margin-top折叠在一起,盒模型border-top的边界定义和它的父元素相同。

另外,任意元素的父元素不参与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):

◆指定了height:auto

◆min-height小于元素的实际使用高度(height)

◆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的值。

viewsourceprint?

1  2  3//不加入br这一行,在FIREFOX中id1的margin-top:20px将会在d0上作用,  使d0上方与body间有20px的间距,d1与d0的上方没有间距,而IE内正常显示   4
5
6

一个简单的例子就是左右两个层,左边层绝对定位,右边层相对定位,右边层的margin-top在firefox下会有问题。解决方法就是,在左边层结束后,清除一次浮动即可。

以上是"margin-top在Firefox失效怎么办"这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!

很赞哦!
元素 模型 浮动 之间 位置 属性 方法 内容 边界 定位 怎么办 兄弟 只有 右边 实际 就是 篇文章 绝对值 间距 高度 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 博兴文件审批oa软件开发 无线网络技术应用的基本原理 网络安全专业有必要吗 网络安全进入校园美术画 剑网3无法更改服务器 进口分布式实时数据库报价 安装pb显示无法启动数据库 深圳网络安全技术培训学校 数据库维护要会编程吗 网易互娱软件开发怎么样 增强网络安全意识 提升 泰思互联网科技中心 数据库管理软件 mac 软件开发前端框架技术 中国网络安全技术产业增速 明星对互联网科技的评论 吧鉴定网络安全海报 服务器 网页跳转 软件开发环境要求 如何设置ksweb的数据库密码 软件开发敏捷型 软件开发年底要不要离职 网络安全可视化监控 杨紫一起关注网络安全 网络安全黑板报图片大全 软件开发过程监控pmo 软件开发 三星笔记本电脑 常熟运营网络技术咨询热线 网络与服务器无法连接 上海失信人员数据库
0