`

margin的基本特性

阅读更多

元素盒模型

margin 在中文中我们翻译成外边距或者外补白(本文中引用外边距)。他是元素盒模型(box model)的基础属性。

一、margin的基本特性

margin 属性包括 margin-top, margin-right, margin-bottom, margin-left, margin,可以用来设置 box 的 margin area。属性 margin 可以用来同时设置 box 的四边外边距,而其他的 margin 属性只能设置其自各的外边距。

margin 属性可以应用于几乎所有的元素,除了表格显示类型(不包括 table-caption, table and inline-table)的元素,而且垂直外边距对非置换内联元素(non-replaced inline element)不起作用。

或许有朋友对非置换元素(non-replaced element)有点疑惑,稍微帮助大家理解一下。非置换元素,W3C 中没有给出明确的定义,但我们从字面可以理解到,非置换元素对应着置换元素(replaced element),也就是说我们搞懂了置换元素的含义,就懂了非置换元素。置换元素,W3C中给出了定义:

“An element that is outside the scope of the CSS formatter, such as an image, embedded document, or applet”

从定义中我们可以理解到,置换元素(replaced element)主要是指 img, input, textarea, select, object 等这类默认就有 CSS 格式化外表范围的元素。进而可知,非置换元素(non-replaced element)就是除了 img, input, textarea, select, object 等置换元素以外的元素。

margin 始终是透明的。

二、margin 的基本写法

外边距的 margin-width 的值类型有:auto | length | percentage

percentage:百分比是由被应用 box 的containing block(注:一个元素的 containing block 是该元素产生的 box(es)在计算位置和大小时参考的一个矩形)的大小所决定。对于 margin-top 和 margin-bottom 也同样成立。

margin 的默认值为 0,并且 margin 支持负值。

上面我们曾提到属性 margin 可以用来同时指定 box 的四边外边距。如果属性 margin 有四个值,那么值将按照上-右-下-左的顺序作用于四边,即从元素的上边开始,按照顺时针的顺序围绕元素。表达式如下:

margintop right bottom left

四个数值中间以空格分隔。效果等同于:

margin-top:value;
margin-right:value;
margin-bottom:value;
margin-left:value;

并且规范还提供了省略的数值写法,基本原则如下:

  1. 如果没有 left 值,则使用 right 代替;
  2. 如果没有 bottom 值,则使用 top 代替;
  3. 如果没有 right 值,则使用 top 值代替。

根据这些基本原则,我们可以有三种省略方式,但不管怎样省略 margin 的数值都会大于等于一个,而 margin 的默认数值是从 top 开始至 left 结束,那么对于省略的具体情况,我们可以从 left 反推理回去。

1、如果 margin 只有三个值,按照值的顺序为 margin:top right bottom; 缺少了 left,根据原则,则 left 的值有 right 来代替。margin:10px 20px 30px; 就等于 margin:10px 20px 30px 20px;

2、如果 margin 只有两个值,按照值的顺序为 margin:top right; 缺少了 bottom 和 left,根据原则 left 的值由 right 来代替,bottm 的值由 top 来代替。margin:10px 20px; 就等于 margin:10px 20px 10px 20px;

3、如果 margin 只有一个值,按照值的顺序为 margin:top; 缺少了 bottom、left 和 right,根据原则 left 的值由 right 来代替,bottom 的值由 top 来代替,right 的值右 top 来代替,也就是说 left 的值也由 top 来代替。margin:10px; 就等于 margin:10px 10px 10px 10px;

三、margin的解析逻辑

目前我们已经了解到了 margin 的基本特性和基本写法,但对元素 margin 的基本解析逻辑还是很模糊,到底 margin 的 top、right、bottom、left 都是以什么为基准来促使 box model 形成。为了形象,易懂的对 margin 的逻辑进行说明,下面讲解的过程中,将引入 W3C 上没有的参考线的说法。何谓参考线?参考线就是 margin 移动的基准点,此基准点相对于 box 是静止的。而 margin 的数值,就是 box 相对于参考线的位移量。

在 margin 中 top、right、bottom、left 的参考线并不一致为一类,而是分为了两类参考线,top 和 left 的参考线属于一类,right 和bottom 的参考线属于另一类。那他们到底各以什么为参考线呢?top 以 containing block 的 content 上边或者垂直上方相连元素 margin 的下边为参考线垂直向下位移;left 以 containing block 的 content 左边或者水平左方相连元素 margin 的右边为参考线水平向右位移。right 以元素本身的 border 右边为参考线水平向右位移;bottom 以元素本身的border 下边为参考线垂直向下位移。从上我们可以看到 top 和 left 都是以外元素为参考,而 right 和 bottom 以本元素为参考。上面的位移方向是指 margin 数值为正值时候的情形,如果是负值则位移方向相反。

margin的移动示例图

或许理论听起来比较枯燥,我们举例说明一下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<style type="text/css">
div {
        width:200px;
        height:200px;
        background:#ccc;
}
</style>
</head>    

<body>
        <div>外边距的margin-width的值类型有:auto | length | percentage</div>
</body>
</html>

如上代码,很简单,为了方便我们看到效果,我们给 div 设置了宽度和高度以及背景色。

现在我们给 div 的样式加上 margin 属性,比如:

margin:-10px 20px -30px 40px;

这时候 margin 的解析逻辑是怎样的呢?首先我们要搞清 div 的和周边元素的关系,div 没有相连元素,而此时 div 的 containing block 是 body 产生的 block box。则根据上面介绍的参考线原理,div 的左外边距以 containing block 的 content 左边为参考线,及此时以 body 的 content 左边为参考线进行水平向右位移,位移的大小为 40px,同理,上边距以 body 的 content 上边为参考线进行垂直向上位移 10px(负值和正值的方向相反),下边距依照现在 div 的 borer 下边(此时的 div 已经经过上边距位移过了)垂直向上位移 30px(此时,margin 不会改变 box 的 border 内的物理大小,但会改变 box 的逻辑大小,即:以此 box 的 margin 的下边为参考的元素,不是从 box 的物理位置开始的,而是从逻辑位置开始),右边距依照现在 div 的 borer 右边(此时的 div 已经经过左边距位移过了)水平向右位移 20px。或许有朋友问你分析的顺序怎么和 margin 表达式中出现的顺序不一样?如果按照 margin 表达式中出现的顺序来分析,结果是一样的,只是为了更好的方便大家的理解而没有按照表达式的顺序来分析。

margin的详解

用 margin 最后的实际显示大小的到底是怎么样呢,或许有朋友也比较疑惑,我暂时用逻辑大小和物理大小来区分(其实上面已用到此概念),到底什么是逻辑大小,什么是物理大小呢?!具体可以看图,物理大小指的是除去 margin,也就是包含 border 以内的 box 大小,而逻辑大小,则是 box 通过 margin 解析规则解析后得到的大小(这或许可以解释为什么IE5会错误解析盒模型)。在上图中,box 的实际显示的宽度等于 box 的逻辑大小,而 box 实际显示的高度等于 box 的物理大小,这说明 box 实际显示的大小可能是 box 的逻辑大小,也可能是 box的 物理大小,规则到底是怎样的——

box 的实际大小 = box 的物理大小 + 正的 margin

这仅对元素本身有效,对于其后面的相关元素,他们则只以 margin 的逻辑大小为准则,进行布局。

有朋友反应,听得很迷糊,越看越不懂,如果你对具体的理解过程不感兴趣的话,那记住下面我总结的结论就可以了,XD

结论:

box 最后的显示大小等于 box 的 border 及 border 内的大小加上正的 margin 值。而负的 margin 值不会影响 box 的实际大小,如果是负的 top 或 left 值会引起 box 的向上或向左位置移动,如果是 bottom 或 right 只会影响下面 box 的显示的参考线。

  • 大小: 7.1 KB
分享到:
评论

相关推荐

    margin负值之美

    首先,理解`margin`的基本概念是关键。`margin`允许我们在元素的四周创建空白区域,通过设置`margin`的大小,我们可以调整元素与其他元素或容器边缘的距离。`margin`的值可以是正数,表示增加距离;也可以是负数,这...

    css中margin属性详细分析 (2).pdf

    首先,我们要明确margin的基本概念。在CSS中,margin属性用于设置元素的上下左右四个方向的外边距。它可以单独设置每个方向的值,如`margin-top`、`margin-right`、`margin-bottom`和`margin-left`,也可以使用简写...

    css中margin属性详细分析.docx

    理解margin的特性和使用方法对于创建具有良好布局的网页至关重要。 首先,margin属性可以独立设置上、右、下、左四个方向的外边距,分别对应margin-top、margin-right、margin-bottom和margin-left。同时,CSS允许...

    请不要告诉我你懂css margin

    《深入理解CSS margin:超越基础,挖掘特性与实践智慧》 在CSS布局中,margin是一个不可或缺的概念,它决定了元素间的距离和视觉空间的分布。然而,对于许多开发者来说,margin的理解可能仅停留在基本的设置间距上...

    行业分类-物理装置-一种损失函数中margin参数值的更新方法和系统.zip

    或者在批量学习中,根据训练集的整体特性来逐步优化margin。 系统层面,这种方法可能涉及以下步骤: 1. 初始化margin参数:根据先验知识或经验值设置初始的margin值。 2. 训练迭代:在每次迭代中,计算损失函数,...

    正确理解CSS中的margin合并的用法

    首先,我们来看一下margin合并的基本概念。在块级元素中(不包括浮动元素和绝对定位元素),上下外边距(margin-top和margin-bottom)有时会合并为一个单一的外边距。这种合并只发生在与文档流方向垂直的方向上。这...

    基于最大margin的决策树归纳.pptx

    SVM基本问题是寻找一个线性分类器,即通过找到一个权重向量w和偏置项b,使得数据点能够在最大间隔的情况下被正确分类。间隔是分类边界与最近的数据点之间的距离,表示模型的鲁棒性和泛化能力。在二维平面上,这可以...

    margin_Budget_卫星通信链路预算_卫星通信_卫星参数MARGIN_matlab.zip

    一、卫星通信链路预算的基本概念 链路预算是一种估算通信链路性能的技术,主要包括发射功率、接收灵敏度、路径损耗、天线增益、馈线损耗、噪声温度等参数的计算。在卫星通信中,链路预算的目的是确保信号在传输过程...

    css margin属性深入解析

    ### `margin`的基本特性 1. **边距合并**:当上下相邻的两个元素的外边距都是正数时,它们之间会发生外边距合并,取两者中较大的那个作为实际的外边距。这种现象在页面布局中很常见,有时需要通过设置负值外边距来...

    CSS中的边界margin的取值为负值说明

    在CSS(层叠样式表)中,边界margin的取值确实可以是负值,这是一个非常实用且富有创意的特性。负边距可以帮助我们调整元素的位置,实现一些特殊布局或者交互效果,尤其在处理复杂的网页布局时能发挥重要作用。让...

    Matlablagleadseriesdesigncorrection.rar_40_phase margin_超前校正_超前滞

    1. **建立原始系统模型**:首先,我们需要创建系统的基本模型,这可能是通过传递函数、状态空间方程或零极点增益模型来完成的。 2. **确定设计参数**:根据要求,设定相角裕量目标和剪切频率。 3. **设计校正器**...

    CSS margin属性介绍与用法(附margin解剖图)

    `margin`属性还有其他特性,比如自动外边距(`margin: auto`),它通常用于居中元素。当元素的左右外边距都设置为`auto`时,浏览器会自动分配空白空间,使元素水平居中。例如: ```css div { width: 200px; ...

    CSS margin全面了解

    本文将全面探讨CSS margin,包括其基本概念、负值的使用以及在流体布局中的应用。 首先,margin属性允许我们在元素的四周边缘设置空间。它接受长度值,可以是像素、百分比、em等单位,也可以是auto,用于自动分配...

    时域特征的求取,例如峭度、裕度等等。

    **裕度(Margin)**通常在控制系统理论中提及,特别是在稳定性分析中。在数字信号处理中,裕度可能指的是信号与系统性能界限之间的距离,例如,在滤波器设计中,它可能是通带和阻带边界的陡峭度。裕度的计算依赖于...

    提取信号时域特征.zip

    2. **信号时域特征**:时域特征是指直接从信号的时间序列中获取的特性,无需进行傅立叶变换或其他频域转换。常见的时域特征包括均值、方差、峰值、极值、峭度、歪度等。这些特征对理解信号的基本动态行为非常有帮助...

    CSS的基本语法.rar

    9. **盒模型(Box Model)**:CSS盒模型包括内容(content)、内边距(padding)、边框(border)和外边距(margin),理解盒模型对于布局至关重要。 10. **响应式设计(Responsive Design)**:CSS3引入了媒体查询...

    HTML5+CSS3 盒的基本类型.docx

    在实际开发中,了解并熟练运用盒模型是每个前端开发者的基本功,它能够帮助我们构建出美观、易用且布局合理的网页。结合HTML5的新特性,如Flexbox和Grid布局,我们可以实现更高级的布局控制,满足现代网页设计的复杂...

    css基本布局,样式表

    盒模型包括内容区域(content)、内边距(padding)、边框(border)和外边距(margin)。默认情况下,浏览器采用W3C盒模型,其中宽度和高度只包含内容区域;但IE6及以下版本使用不同的盒模型,包括内容、内边距和...

Global site tag (gtag.js) - Google Analytics