网站推广.NET

网站推广.NET

CSS属性box-sizing详解

来源:互联网

css盒模型

你需要先了解CSS盒模型

CSS盒模型中 width 与 height 的计算规则:

在CSS中,你设置一个元素的width与height只会应用到这个元素的内容区。如果这个元素有任何的 border 或 padding,绘制到屏幕上时的盒子宽度和高度会加上设置的边框(border)和内边距(padding)值。

下面举例说明

立即学习“前端免费学习笔记(深入)”;

不加 padding 与 border 的时候

<body>  <p class="wrapper"></p></body>
*{      margin:0;      padding:0;    }    body{      border:1px solid blue;      margin:10px;    }    .wrapper{      width:100px;      height:100px;      background:pink;    }

此时 p.wrapper 元素的宽高是 100*100

wrapper元素的盒模型

当给 p.wrapper 元素加上 padding 和 border 样式时

.wrapper{      width:100px;      height:100px;      background:pink;      padding:10px;      border:1px solid black;      margin:10px;    }

此时 p.wrapper 元素的宽高是 122*122 ,因为给该元素加上了10像素的 padding 和1像素的 border,可以看到此时粉色区域要更大了

box-sizing属性

1. box-sizing 属性是干什么用的?

box-sizing 属性是用来更改 CSS盒模型 中的这种 计算元素宽高 的一种方法

2. box-sizing 的取值

content-box

是默认值。如果你设置一个元素的宽为100px,那么这个元素的内容区会有100px宽,并且任何边框和内边距的宽度都会被增加到最后绘制出来的元素宽度中。

border-box

如果你将一个元素的 width 设为100px,那么这100px会包含它的 border 和 padding,内容区的实际宽度会是 width 减去 border + padding 的计算值。

3. 使用 box-sizing 属性

使用 border-box

<body>  <p class="wrapper"></p></body>
    *{      margin:0;      padding:0;      box-sizing:border-box;    }    body{      border:1px solid blue;      margin:10px;    }    .wrapper{      width:100px;      height:100px;      background:pink;      margin:10px;      padding:10px;      border:1px solid black;    }

此时 p.wrapper 元素的宽高还是 100*100,但实际内容区的宽高变成 78*78,元素的宽高包括实际内容的宽高加上 border 和 padding 的值

使用content-box

box-sizing