css盒子模型
css盒子模型概念
CSS盒子模型又称框模型(Box Model),包含了元素内容(content)、内边距(padding)、边框(border)、外边框(margin)几个要素。如图:
图中最内部的框是元素的实际内容,也就是元素框,紧挨着元素框外部的是内边距padding,其次是边框(border),然后最外层是外边距(margin),整个构成了框模型。通常我们设置的背景显示区域,就是内容、内边距、边框这一块范围。而外边框margin是透明的,不会遮挡周边的其他元素。
那么,元素框的总高度 = 元素(element)的width+padding的左右边距 + margin的左右边距 + boder的左右宽度;
元素框的总高度 = 元素(element)的height + padding的上下边距 + margin的上下边距 + boder的上下宽度。
CSS外边距合并(叠加)
两个上下方向相邻的元素框垂直相遇时,外边距会合并,合并后的外边距的高度等于两个发生合并的外边距中较高的那个边距值,如图:
比较容易理解,所以在页面中有时候遇到实际情况是需要考虑这个因素的。当然外边距合并其实也有存在的意义,如下图
需要注意的是:只有普通文档流中块框的垂直外边距才会发生外边距合并。行内框、浮动框或绝对定位之间的外边距不会合并。
css reset中也会经常用到
- {
margin: 0;
padding: 0;
}
box-sizing属性介绍
box-sizing属性是用户界面属性里的一种,之所以介绍它,是因为这个属性跟盒子模型有关,而且在css reset中有可能会用到它。
box-sizing : content-box | border-box | inhert;
- content-box:默认值,可以使设置的宽度和高度值应用到元素的内容框。盒子的width只包含内容。
即总宽度 = margin + border + padding + width
- border-box:设置的width值其实是除margin外的border+padding+element的总宽度。盒子的width包含boder+paading+内容
即总宽度 = margin + width
很多CSS框架,都会对盒子模型的计算方法进行简化。
- inherit:规定应从父元素继承box-sizing属性的值
关于border-box的使用:
- 一个box宽度为100%,又想要两边有内间距,这时候用就比较好
- 全局设置border-box很好,首先符合直觉,其次它可以省去一次又一次的加加减减,它还有一个关键作用-让有边距的盒子正常使用百分比宽度
实际开发中遇到的和框模型相关的应用及小问题
- margin越界(第一个子元素的margin-top和最后一个子元素的margin-bottom的越界问题)
以第一个子元素的margin-top为例:
当元素没有边框border时,设置第一个子元素的margin-top值的时候,会出现margin-top值加在父元素上的现象,解决方法有四个:
- 给父元素加边框border(副作用)
- 给父元素设置padding值(副作用)
- 父元素添加overflow:hidden(副作用)
- 父元素加前置内容生成。(推荐)
以第四种方法为例:
.parent {
500px;
height: 500px;
background-color: red;
}
.parent: before{
content: " ";
display: table;
}
.child{
200px;
}
<div clas="parent">
<div class="child"></div>
</div>
用盒子模型绘制彩色矩形
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
<style type="text/css">
div {
0px;
height: 0px;
border: 50px solid green;
border-top-color: lightpink;
border-left-color: lightskyblue;
border-right-color: lightsteelblue;
border-bottom-color: lightgoldenrodyellow;
}
</style>
</head>
<body>
<div></div>
</body>
</html>
效果为: