什么是盒子模型?
- 盒子模型组成有 4 局部, 别离为: 内容 内边距 外边距(个别不计入盒子理论宽度) 边框
- 盒子模型有 2 种: 规范盒子模型与怪异盒子模型
- 规范盒子模型 =content(内容)+border(边框)+padding(内边距)
- 怪异盒子模型 =content(内容)(曾经蕴含了 padding 和 border)
- css3 种能够通过设置 box-sizing 属性来实现规范或者怪异盒子模型之间的切换, 怪异盒子模型:box-sizing: border-box; 规范盒子模型:box-sizing:content-box
当对一个文档进行布局(layout)的时候,浏览器的渲染引擎会依据规范之一的 CSS 根底框盒模型(CSS basic box model),将所有元素示意为一个个矩形的盒子(box)
一个盒子由四个局部组成:content、padding、border、margin
content
,即理论内容,显示文本和图像
boreder
,即边框,围绕元素内容的内边距的一条或多条线,由粗细、款式、色彩三局部组成
padding
,即内边距,革除内容四周的区域,内边距是通明的,取值不能为负,受盒子的 background 属性影响
margin
,即外边距,在元素外创立额定的空白,空白通常指不能放其余元素的区域
上述是一个从二维的角度观察盒子,上面再看看看三维图:
上面来段代码
<style>
.box {
width: 200px;
height: 100px;
padding: 20px;
}
</style>
<div class="box"> 盒子模型 </div>
当咱们在浏览器查看元素时,却发现元素的大小变成了 240px
这是因为,在 CSS 中,盒子模型能够分成:
- W3C 规范盒子模型
- IE 怪异盒子模型
默认状况下,盒子模型为 W3C 规范盒子模型
规范盒子模型
规范盒子模型,是浏览器默认的盒子模型
上面看看规范盒子模型的模型图:
从上图能够看到:
- 盒子总宽度 = width + padding + border + margin;
- 盒子总高度 = height + padding + border + margin
也就是,width/height 只是内容高度,不蕴含 padding 和 border 值
所以下面问题中,设置 width 为 200px,但因为存在 padding,但实际上盒子的宽度有 240px
IE 怪异盒子模型
同样看看 IE 怪异盒子模型的模型图:
从上图能够看到:
- 盒子总宽度 = width + margin;
- 盒子总高度 = height + margin;
也就是,width/height 蕴含了 padding 和 border 值
Box-sizing
CSS 中的 box-sizing 属性定义了引擎应该如何计算一个元素的总宽度和总高度
语法
box-sizing: content-box|border-box|inherit:
- content-box 默认值,元素的 width/height 不蕴含 padding,border,与规范盒子模型体现统一
- border-box 元素的 width/height 蕴含 padding,border,与怪异盒子模型体现统一
-
inherit 指定 box-sizing 属性的值,应该从父元素继承
回到下面的例子里,设置盒子为 border-box 模型<style> .box { width: 200px; height: 100px; padding: 20px; box-sizing: border-box; } </style> <div class="box"> 盒子模型 </div>
这时候,就能够发现盒子的所占据的宽度为 200px
本文由 mdnice 多平台公布