CSS重要属性之 margin 属性知识大合集介绍

以下的分享是本人最近几天学习了margin知识后,大有启发,感觉以前对margin的了解简直太浅薄。所以写成以下文章,一是供自己整理思路;二是把知识分享出来,避免各位对margin属性的误解。内容可能会有点多,但都是精华,希望大家耐心学习。

以下的分享会分为如下内容:

1.margin 属性的简单介绍

  1.1:普通流的 margin 百分比设置

  1.2:绝对定位的 margin 百分比设置

立即学习“前端免费学习笔记(深入)”;

2.margin 无法适用的元素

3.外边距折叠 (Collapsing margins)

  3.1:Collapsing margins 初衷

  3.2:Collapsing margins 类型

    3.2.1:兄弟元素的 margin 重叠

    3.2.2:父子元素的 margin 重叠

    3.2.3:元素自身的 margin-bottom 和 margin-top 相邻时也会折叠

4.折叠后 margin 的计算规则

  4.1:参与折叠的 margin 都是正值

  4.2:参与折叠的 margin 都是负值

  4.3:参与折叠的 margin 中有正值,有负值

5.Collapsing margins 解决方法

1.margin 属性的简单介绍

在介绍margin之前,先剖上一张W3C标准盒模型的图片,以便读者可以查看相关位置。

  CSS重要属性之 margin 属性知识大合集介绍

margin,顾名思义,叫做外边距。

margin的基本属性有以下几点

a:margin 是 ‘margin-top’, ‘margin-right’, ‘margin-bottom’, ‘margin-left’ 的简写,表明 margin 的大小范围。

b:margin 值可以是 宽度值、百分比值或 ‘auto’ 这3者之一。注意,margin 必须带有单位,单位可以是像素、英寸、毫米或 em。

c:margin 百分比值是相对于父元素的 width 计算的。

d:当 margin 为 margin:10px 时,表示 top,right,bottom,left (逆时针)方向都是10px;当 margin 为 margin:10px 20px 时,表示上下方向为10px,左右方向为20px;当 margin 为 margin:10px 20px 5px 时,表示top方向为10px,左右方向为20px,bottom方向为5px;当 margin 为 margin:1px 2px 3px 4px 时,表示top方向为1px,right方向为2px,bottom方向为3px,left方向为4px。

上面通过对 margin 的简单介绍,我们知道 margin 的百分比值是相对于父元素的 width 计算的,但是普通流和绝对定位元素的margin的计算是又是不相同的。

1.1:普通流的 margin 百分比设置

在普通流元素中,margin 百分比值得计算是依据其父元素的 width 计算的。

.container {           width: 300px;           height: 300px;           background-color: lightpink;           margin: 10px;           display: inline-block;            }         .container .content {           width: 120px;           height: 120px;           background-color: lightgreen;           margin: 10%;         }

CSS重要属性之 margin 属性知识大合集介绍

可以看出, top left 方向的 margin 都是30px ( 300 * 10% = 30)。为父元素设置display是有原因的,会在下面小节提到,稍安勿躁。

注意,margin 四个方位的值都是依据父元素的 width 计算!

  1.2:绝对定位的 margin 百分比设置

在绝对定位元素中,父元素若设置了relative/absolute/fixed,则 margin 百分比值是依据父元素的 width 计算的;父元素若无设置relative/absolute/fixed,则 margin 百分比值是依据 整个页面的 width 计算的。

.container {     width: 300px;     height: 300px;     background-color: lightpink;     display: inline-block;   }   .container .content {     width: 120px;     height: 120px;     background-color: lightgreen;     position: absolute;   /*增加了改该属性*/  margin: 10%;   }

CSS重要属性之 margin 属性知识大合集介绍

可以看出,margin 的值计算结果不再是30px了,而是变成 137px (我的电脑页面宽度为1370px)。这是因为子元素container设置了absolute,导致子元素脱离文档流,四个方位的值是依据页面进行定位,所以 margin值才会发生变化。如果想让子元素还是依据父元素定位,可以为父元素设置 relative/fixed/absolute 其中之一个值, 这样 margin 百分比计算还是 30px,跟普通流中margin 的一样。 同学可以亲自尝试一下。

2.margin 无法适用的元素

  有以下元素设置 margin 值是没有效果的。

  a:行内元素垂直 margin 值不起作用。

  b:margin 非 table 类型的元素,以及 table 类型中 table-caption, table-cell 和 inline-table 这3类。例如 TD TR TH 等,margin 是不适用的。

  c:对于行内非替换元素(例如 SPAN),垂直方向的 margin 不起作用。

3.外边距折叠 (Collapsing margins)

Collapsing margins,即外边距折叠,指的是相邻的两个或多个外边距 (margin) 会合并成一个外边距。margin 折叠 必须发生在普通流元素中。

  3.1:Collapsing margins 初衷

  Collapsing margins 的初衷就是为了让段落显示的更加好看。以由几个段落组成的典型文本页面为例。第一个段落上面的空间等于段落的上外边距。如果没有外边距合并,后续所有段落之间的外边距都将是相邻上外边距和下外边距的和。这意味着段落之间的空间是页面顶部的两倍。如果发生外边距合并,段落之间的上外边距和下外边距就合并在一起,这样各处的距离就一致了。

CSS重要属性之 margin 属性知识大合集介绍

此图来源于 W3C

  3.2:Collapsing margins 类型

    3.2.1:兄弟元素的 margin 重叠

.container {     width: 300px;     height: 300px;     margin-bottom: 10px;     background-color: lightpink;   }   .an-container {     width: 300px;     height: 300px;     margin-top: 10px;     background-color: lightgreen;   }

CSS重要属性之 margin 属性知识大合集介绍

    3.2.2:父子元素的 margin 重叠

两个或多个外边距没有被非空内容、padding、border 或 clear 分隔开

这些 margin 都处于普通流中。

      margin-top 重叠:在没有被分隔的情况下,一个元素的 margin-top 会和它普通流中的第一个子元素(非浮动元素等)的 margin-top 相邻。

.container {     width: 150px;     margin-top: 10px;     background-color: lightpink;   }   .container .an-container {     background-color: lightgreen;     width: 100px;     height: 100px;     margin-top: 10px;   }

CSS重要属性之 margin 属性知识大合集介绍

      margin-bottom 重叠:在没有被分隔的情况下,只有在父元素的 height 是 “auto” 的情况下,它的 margin-bottom 才会和它普通流中的最后一个子元素(非浮动元素等)的 margin-bottom 相邻。就是说,父元素的height值不能是固定高度值。如果父元素固定高度,那么margin-bottom会无效的。代码同上。

    3.2.3:元素自身的 margin-bottom 和 margin-top 相邻时也会折叠

CSS重要属性之 margin 属性知识大合集介绍

以上代码运行后,我们讲得到的是红色边框的正方形,方框的宽高都应该是 100px,高度不应该是 150px。

4.折叠后 margin 的计算规则

  4.1:参与折叠的 margin 都是正值

A

B

CSS重要属性之 margin 属性知识大合集介绍

在 margin 都是正数的情况下,取其中 margin 较大的值为最终 margin 值。

  4.2:参与折叠的 margin 都是负值

A

B

CSS重要属性之 margin 属性知识大合集介绍

当 margin 都是负值的时候,取的是其中绝对值较大的,然后,从 0 位置,负向位移。

  4.3:参与折叠的 margin 中有正值,有负值

A

B

CSS重要属性之 margin 属性知识大合集介绍

如果,相邻的 margin 中有正值,同时存在负值会怎样呢?有正有负,先取出负 margin 中绝对值中最大的,然后,和正 margin 值中最大的 margin 相加。其实也就是正负相加就可以了。

上面的例子最终的 margin 应该是 100 + (-50) = 50px。

5.Collapsing margins 解决方法

解决方法有如下:

a:浮动元素、inline-block 元素、绝对定位元素的 margin 不会和垂直方向上其他元素的 margin 折叠 ( 针对 兄弟元素)

注意: 浮动元素 , inline-block元素 , 绝对定位元素 都属于 BFC元素。

b:创建了块级格式化上下文(BFC, blocking formatting context )的父元素,比如说overflow:hidden,不和它的子元素发生 margin 折叠 (针对 父子元素)。

c:给父元素添加以下内容之一都可以避免发生 margin 重叠 。如 添加内容 , 添加 padding , 添加 border。

虽然有方法解决这个问题。但是目前最好的解决方案是回避这个问题。也就是,不要给指定元素添加具有指定宽度的内边距或外边距,而是尝试将内边距或外边距添加到元素的父元素和子元素。

以上这篇CSS重要属性之 margin 属性知识大整合(必看篇)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持PHP中文网。

更多CSS重要属性之 margin 属性知识大合集介绍相关文章请关注PHP中文网!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1607605.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月23日 20:54:47
下一篇 2025年12月23日 20:56:11

相关推荐

  • css文本样式及控制文本的大小写方法

    常用文本样式如下: text文本样式 h3{ /*text-indent:首行缩进*/ text-indent: -2em; padding-left:2em; /*text-shadow:必需。水平阴影的位置。允许负值。 必需。垂直阴影的位置。允许负值。 可选。模糊距离 可选。阴影颜色*/ tex…

    好文分享 2025年12月23日
    000
  • css 常用样式详细介绍

    font-family 设置字体名称 可以使用多个名称,用逗号分隔,浏览器则按照先后顺序依次使用可用字体 p { font-family:’宋体’,’黑体’,’Arial’; } font-size 设置字体大小 length 用长度值指定文字大小,不允许负值 立即学习“前端免费学习笔记(深入)”;…

    好文分享 2025年12月23日
    000
  • css核心基础的总结

    今日这篇是整合前面的css补充知识的。 我觉得前面的关于css的知识补充进去有点乱,今日整理整理一下。 层叠样式表 层叠是什么意思?为什么这个词如此重要,以至于要出现在它的名称里。 层叠可以简单地理解为冲突的解决方案。 立即学习“前端免费学习笔记(深入)”; 什么是冲突? 就是同个元素在使用不同的选…

    好文分享 2025年12月23日
    000
  • 最全的CSS hack方式一览(兼容多浏览器)

    为了获得统一的页面效果,就需要针对不同的浏览器或不同版本写特定的CSS样式,我们把这个针对不同的浏览器/不同版本写相应的CSS code的过程,叫做CSS hack!做前端多年,虽然不是经常需要hack,但是我们经常会遇到各浏览器表现不一致的情况。基于此,某些情况我们会极不情愿的使用这个不太友好的方…

    2025年12月23日
    000
  • 浅谈css处理水平居中

    下面小编就为大家带来一篇浅谈css处理水平居中的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧,祝大家游戏愉快哦 1、水平居中设置-行内元素 通过父元素设置 1 text-align:center; ,让父元素的内容居中 2、水平居中设置-定宽块状元素 块状元素的…

    好文分享 2025年12月23日
    000
  • 浅谈css和@import区别及用法详解

    下面小编就为大家带来一篇浅谈css和@import区别及用法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 css和@import都是调用外部样式表的方法。 一、用法 (1)link: 立即学习“前端免费学习笔记(深入)”; (2)@import: 方法一(html中…

    好文分享 2025年12月23日
    000
  • 剖析CSS Position定位

           当人们刚接触布局的时候都比较倾向于使用定位的方式。因为定位的概念看起来好像比较容易掌握。表面上你确切地指定了一个块元素所处的位置那么它就会坐落于那里。可是定位比你刚看到的时候要稍微复杂一点。对于定位来说,有一些东西会绊倒新手,所以在它成为你的惯用技巧前你需要掌握它们。   一旦你更深入…

    2025年12月23日
    000
  • CSS的技巧

    有些经典的css技巧,我们还是需要记住的,这样可以节省我们大量的时间,下面零度就为大家推荐几个比较好的css技巧: 1、在不同页面上使用同样的导航代码 许多网页上都有导航菜单,当进入某页时,菜单上相应这一项就应该变灰,而其他页亮起来。一般要实现这个效果,需要写程序或专门为每一页做设计,现在靠CSS就…

    好文分享 2025年12月23日
    000
  • css中px、em和rem的区别

    前言 em 和 rem 都是灵活可扩展的单位,由浏览器转换为像素值,取决于设计中的字体大小,如果使用值 1em 或 1rem ,它可以被浏览器转换为从 16px 到 160px 或其他任意值。浏览器使用 1px ,那么 1px 始终显示为完全 1px。 em 和 rem 的相同点 使用 em 和 r…

    好文分享 2025年12月23日
    000
  • rem — 低调的css单位

    rem这是个低调的 css 单位,近一两年开始崭露头角,有许多同学对rem的评价不一,有的在尝试使用,有的在使用过程中遇到坑就弃用了。但是我对rem综合评价是用来做web app它绝对是最合适的人选之一。 rem是什么? rem(font size of the root element)是指相对于…

    2025年12月23日 好文分享
    000
  • 用CSS实现带箭头的流程进度条

    本文介绍的是利用纯css的带箭头流程进度条,兼容到ie8,需要的朋友们下面来一起学习学习。 首先写出一个基本的样式。 .cssNav li{ padding: 0px 20px; line-height: 40px; background: #50abe4; display: inline-bloc…

    2025年12月23日 好文分享
    000
  • CSS与HTML使用误区

    误区一.多p症  Home About Concact 上述使用使用多余的p标签现状,就称为“多p症”,理应简化成下 Home About Concact误区二.多类class症  注意点class可以应用于页面任意多个元素,非常适合标识内容类型或其他相似的条目 立即学习“前端免费学习笔记(深入)”…

    2025年12月23日
    000
  • CSS属性transparent实现各种三角形示例

    效果图如下 示例代码 *{ margin: 0; padding: 0; } .box{ margin: 40px auto; width: 60px; background-color: #f0ac6b; } .t1{ margin: 40px auto; width: 0px; height: …

    2025年12月23日
    000
  • CSS实现书签效果实例

    这篇文章通过纯css代码写了个书签效果,实现后的书签效果很漂亮,文中给出了完整的示例代码,实现的代码也很简单,很方便大家理解和学习,有需要的朋友们可以参考学习,下面来一起学习学习吧。 实现的效果图如下: 示例代码如下: border制作书签(图形) .p2:before { /*做一个书签效果*/ …

    2025年12月23日
    000
  • CSS设定一个元素半透明

    这篇文章主要介绍了用css设定一个元素半透明的相关资料,非常不错,具有参考借鉴价值,需要的朋友参考下吧 .opacity{ filter:alpha(opacity=50); /* IE */ -moz-opacity:0.5; /* 老版Mozilla */ -khtml-opacity:0.5;…

    好文分享 2025年12月23日
    000
  • css中的三种定位机制

    css中的三种基本定位机制 a.普通文档流 b.定位:相对定位          绝对定位       固定定位 立即学习“前端免费学习笔记(深入)”; c.浮动 1.普通流中,元素位置由文档顺序和元素性质决定,块级元素从上到下依次排列,框之间的垂直距离由框的垂直margin值计算得到,行内元素在一…

    好文分享 2025年12月23日
    000
  • CSS的position定位属性在使用的一些重点

    1.position:static static属性是position的默认值,也就是说,当一个元素没有为其设定position属性时,它的默认值就是static。 2.position:absolute这是一个经常会被用到的position属性值。如果为某个元素设定了absolute,则该元素脱离…

    好文分享 2025年12月23日
    000
  • jimdo能否添加html5弹窗_jimdo弹窗html5代码实现与触发条件【技巧】

    可在Jimdo实现HTML5弹窗的四种方法:一、用内置“弹窗链接”模块;二、通过HTML区块注入精简dialog结构(需配合内联CSS);三、外部托管HTML+iframe嵌入;四、纯CSS :target伪类无JS方案。 如果您希望在Jimdo网站中实现HTML5弹窗效果,但发现平台默认不支持直接…

    2025年12月23日
    000
  • 响应式HTML5按钮适配不同屏幕方法【方法】

    实现响应式HTML5按钮需五种方法:一、CSS媒体查询按max-width断点调整样式;二、用rem/vw等相对单位替代px;三、Flexbox控制容器与按钮伸缩;四、CSS变量配合requestAnimationFrame优化的JS动态适配;五、Tailwind等框架的响应式工具类。 如果您希望H…

    2025年12月23日
    000
  • jimdo如何添加html5表单_jimdo表单html5代码嵌入与字段设置【实操】

    可通过嵌入HTML5表单代码、启用字段验证属性、添加CSS样式反馈及替换提交按钮并绑定JS事件四种方式在Jimdo实现自定义表单行为。 如果您在 Jimdo 网站中需要自定义表单行为或字段逻辑,而内置表单编辑器无法满足需求,则可通过嵌入 HTML5 表单代码实现更灵活的控制。以下是具体操作步骤: 一…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信