HTML中盒子模型间距原理,CSS盒模型与边距重叠

基本概念: 标准模型 + IE 模型

基本模型和 IE 模型的区别:计算宽度和高度的不同

CSS 如何设置这两种模型(由理论转为运用)

JS 如何设置、获取盒模型对应的宽和高

实例题(根据盒模型解释边距重叠问题) 拔高性的延伸

BFC (边距重叠解决方案)面试常考,也容易混淆的题目

d73f03cc8be2

标准模型.png

d73f03cc8be2

IE模型.png

CSS 如何设置这两种模型

标准模型:box-sizing: content-box;

IE 模型:box-sizing: border-box;

JS 如何设置盒模型对应的宽和高

dom.style.width/height : 只能取出内联样式的宽和高 eg:

dom.currentStyle.width/height 获取即时计算的样式,但是只有 IE 支持,要想支持其他浏览器,可以通过下面的方式

window.getComputedStyle(dom).width: 兼容性更好

dom.getBoundingClientRect().width/height: 这个较少用,主要是要来计算在页面中的绝对位置

边距重叠

什么是边距重叠呢?

边界重叠是指两个或多个盒子(可能相邻也可能嵌套)的相邻边界(其间没有任何非空内容、补白、边框)重合在一起而形成一个单一边界。

父子元素的边界重叠

.parent {

background: #e7a1c5;

}

.parent .child {

background: #c8cdf5;

height: 100px;

margin-top: 10px;

}

在这里父元素的高度不是 110px,而是 100px,在这里发生了高度坍塌。

原因是如果块元素的 margin-top 与它的第一个子元素的 margin-top 之间没有 border、padding、inline content、 clearance 来分隔,或者块元素的 margin-bottom 与它的最后一个子元素的 margin-bottom 之间没有 border、padding、inline content、height、min-height、 max-height 分隔,那么外边距会塌陷。子元素多余的外边距会被父元素的外边距截断。

兄弟元素的边界重叠

#margin {

background: #e7a1c5;

overflow: hidden;

width: 300px;

}

#margin > p {

background: #c8cdf5;

margin: 20px auto 30px;

}

1

2

3

可以看到 1 和 2,2 和 3 之间的间距不是 50px,发生了边距重叠是取了它们之间的最大值 30px。

空元素的边界重叠

假设有一个空元素,它有外边距,但是没有边框或填充。在这种情况下,上外边距与下外边距就碰到了一起,它们会发生合并

BFC

解决上述问题的其中一个办法就是创建 BFC。BFC 的全称为 Block Formatting Context,即块级格式化上下文。

处于同一个 BFC 中的元素相互影响,可能会发生 margin collapse;

BFC 在页面上是一个独立的容器,容器里面的子元素不会影响到外面的元素,反之亦然;

计算 BFC 的高度时,考虑 BFC 所包含的所有元素,包括浮动元素也参与计算;

浮动盒的区域不会叠加到 BFC 上;

防止垂直 margin 重叠

父子元素的边界重叠得解决方案: 在父元素上加上 overflow:hidden;使其成为 BFC。

.parent {

background: #e7a1c5;

overflow: hidden;

}

兄弟元素的边界重叠,在第二个子元素创建一个 BFC 上下文:

1

2

3

清除内部浮动

#float {

background: #fec68b;

}

#float .float {

float: left;

}

我是浮动元素

父元素#float 的高度为 0,解决方案为为父元素#float 创建 BFC,这样浮动子元素的高度也会参与到父元素的高度计算:

#float {

background: #fec68b;

overflow: hidden; /*这里也可以用float:left*/

}

自适应两栏布局

#layout {

background: red;

}

#layout .left {

float: left;

width: 100px;

height: 100px;

background: pink;

}

#layout .right {

height: 110px;

background: #ccc;

}

在这里设置右边的高度高于左边,可以看到右边超出的部分跑到左边去了,这是由于由于浮动框不在文档的普通流中,所以文档的普通流中的块框表现得就像浮动框不存在一样导致的。

解决方案为给右侧元素创建一个 BFC,原理是 BFC 不会与 float 元素发生重叠。

#layout .right {

height: 110px;

background: #ccc;

overflow: auto;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值