margin

1. margin 与容器尺寸

两种容器尺寸:

  1. 可视尺寸:含 border 及以内的尺寸—— clientWidth、clientHeight(标准)
  2. 占据尺寸:含 margin 及以内的尺寸—— outerWidth、outerWidth(非标准,YY)

1.1. margin 与可视尺寸

生效条件:

  1. 适用于没有设定 width/height 的普通 block 水平元素(float 就不行)。
  2. 只适用于水平方向尺寸(这种情况就不考虑设置 height 的情况了)。

1.2. margin 与占据尺寸

  1. block/inline-block 水平元素均适用
  2. 与有没有设置 width/height 值无关
  3. 适用于水平方向和垂直方向
    例子是:修改子元素的 margin-bottom: -30px,则父元素的高度减少 30px。
    实例:实现滚动容器上下留白的效果。如果通过在滚动容器上使用 padding 来实现,会发现在非 Chrome 浏览器下,底部 padding 不见了。所以通过在子元素上设置 margin 来实现。

2. margin 与百分比属性值

计算规则:

  1. 普通元素:无论水平方向还是垂直方向都是相对于容器的 width 来计算的
  2. 绝对定位元素:相对于第一个具有定位属性的祖先元素(relative/absolute/fixed)的 width 计算的

特性实例:

  1. 宽高 2:1 自适应布局
.container {
  /* overflow: hidden 是为了避免发生 margin 重叠的现象 */
  overflow: hidden;
}
.container>div {
  margin: 50%;
}
 /* 垂直方向通过 margin 重叠,导致高度只有 50%;而宽度始终是 100% */
<div class="container">
  <div />
</div>

3. margin 重叠

通常特性

  1. margin 重叠只发生在 block 水平元素(不包括 float 和 absolute 元素)
  2. 不考虑 writing-mode,只发生在垂直方向上(margin-top/margin-bottom)

margin 重叠的 3 种情形

  1. 相邻的兄弟元素
  2. 父级和第一个(或最后一个)子元素。这时子元素不会把父元素撑开,其表现为子元素的 margin 赋给了父元素,父元素位置改变。父子 margin 重叠的其他条件:

对于 margin-top 重叠

  • 父元素非 BFC 元素
  • 父元素没有 border-top 设置
  • 父元素没有 padding-top 值
  • 父元素和第一个子元素之间没有 inline 元素分隔

对于 margin-bottom 重叠

  • 父元素非 BFC 元素
  • 父元素没有 border-bottom 设置
  • 父元素没有 padding-bottom 值
  • 父元素和最后一个子元素之间没有 inline 元素分隔
  • 父元素没有 height, min-height, max-height 限制
  1. 空的 block 元素
    发生重叠的条件:
  • 元素没有 border 设置
  • 元素没有 padding 值
  • 里面没有 inline 元素
  • 没有 height 和 min-height

margin 的计算规则

  1. 正正取大值
  2. 正负值相加
  3. 负负取小值

4. margin: auto

元素有时候,就算没有设置 width/height,也会自动填充满整个容器。
比如:

  1. 普通水平块元素 div
  2. position: absolute; left: 0; right: 0; (top: 0; bottom: 0; 可填充高度)

如果设置了 width/height,自动填充特性就会被覆盖。原本应该填充的尺寸被 width/height 强制变更,而 margin: auto 就是为了填充这个变更的尺寸设计的。

4.1 计算规则

  1. 如果一侧是 auto,另一侧非 auto,则设置 auto 一侧的 margin 为剩余空间大小。
  2. 如果两侧都是 auto,则平分剩余空间大小。

4.2 实例

  1. 实现水平居中。但是如果计算后的 margin 为负值,则元素不能水平居中。

5. margin 负值定位

5.1 实例

  1. 如果能自动填充的元素没有设置 width/height,通过设置 margin 为负值,相当于增加了容器的 width/height。

  2. 实现两列等高布局
    副作用:貌似会在移动端 focus 的时候重定位 scroll 导致页面飞掉(由于设置了 overflow: hidden ),mark 一下....


    通过 margin 和 padding 实现两列登高布局
  3. 使用 margin 负值实现两栏自适应布局
    同 float 实例:

使用 margin 负值实现两栏自适应布局

6. margin 失效情形

1. inline 元素垂直方向 margin

失效前提条件:

  • 非替换元素,如 img
  • 正常书写模式 writing-mode

2. margin 重叠

3. display: table-cell 与 margin

当 display 设置为 table-* 值时,margin 无效。

4. 绝对定位元素非定位方位的 margin 值“无效”

这里的“无效”是指:对绝对定位元素非定位方位设置 margin 值,对元素的定位是没有影响的,但是实际上 margin 还是改变了元素的“占据尺寸”的,即 margin 是有效的。

5. 鞭长莫及

实际上是因为:margin-left 不够大。


效果图

6. 内联特性导致 margin 无效

如图,无论再怎么减小 margin-top 的值,图片的位置都不会改变。
原因是:图片含内联特性,由于 vertical-align 默认为 baseline 对齐;由于内容 x 不会跑到容器外面去,所以受到 vertical-align 属性的拖累,图片位置被限制了。


效果图
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容