CSS的盒模型

174 阅读1分钟

1、盒子模型(Box Model )

盒子模型可以用来对元素进行布局,包括内边距(padding)、边框(border)、外边距(margin)和实际内容(content)这几个部分。

盒子模型分为两种:

  • 第一种是 W3C 标准的盒子模型(标准盒模型)
  • 第二种是 IE标准的盒子模型(怪异盒模型)

1.1标准盒模型

标准盒模型width 指的是内容区域 content 的宽度,height指的是内容区域 content的高度

标准盒模型下盒子的大小= content+border+padding+margin

1.2怪异盒模型

怪异盒模型width指的是内容区域contet、边框border、内边距padding总的宽度

怪异盒模型下盒子的大小=width(content+border+padding)+margin

2、如何设置盒模型?

我们可以通过属性 box-sizing 来设置盒子模型的解析模式

W3C标准的标准盒模型(default):box-sizing:content-box;

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
            box-sizing: content-box;
        }
        .box {
            width: 200px;
            height: 200px;
            padding: 20px;
            margin: 20px;
            border: 2px solid skyblue;
            background-color: pink;
        }
    </style>
</head>
<body>
    <div class="box"></div>
</body>
</html>

image.png

IE 标准的怪异盒子模型:box-sizing:border-box;

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
            box-sizing: border-box;
        }
        .box {
            width: 200px;
            height: 200px;
            padding: 20px;
            margin: 20px;
            border: 2px solid skyblue;
            background-color: pink;
        }
    </style>
</head>
<body>
    <div class="box"></div>
</body>
</html>

image.png