乐趣区

关于前端:什么是盒子模型

什么是盒子模型?

  • 盒子模型组成有 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 多平台公布

退出移动版