CSS 框模型 (Box Model) 规定了元素框处理元素内容、内边距、边框 和 外边距 的方式。
一、CSS 框模型概述
元素框的最内部分是实际的内容,直接包围内容的是内边距。内边距呈现了元素的背景。内边距的边缘是边框。边框以外是外边距,外边距默认是透明的,因此不会遮挡其后的任何元素。
提示:背景应用于由内容和内边距、边框组成的区域。
内边距、边框和外边距的默认值是零。但是,许多元素将由用户代理样式表设置外边距和内边距。可以通过将元素的 margin 和 padding 设置为零来覆盖这些浏览器样式。
可以使用通用选择器对所有元素进行设置
* {
margin: 0;
padding: 0;
}
二、宽度和高度
在 CSS 中,width 和 height 指的是内容区域的宽度和高度。增加内边距、边框和外边距不会影响内容区域的尺寸,但是会增加元素框的总尺寸。
假设框的每个边上有 10 个像素的外边距和 5 个像素的内边距。如果希望这个元素框达到 100 个像素,就需要将内容的宽度设置为 70 像素,请看下图:
#box {
width: 70px;//元素宽度
height: 50px;//元素高度
margin: 10px;//元素外边距
padding: 5px;//元素内边距
}
三、内边距
提示:内边距、边框和外边距可以应用于一个元素的所有边,也可以应用于单独的边。
提示:padding属性值赋值规则:
padding:5px; 表示四周内边距为5像素
padding:5px 0; 表示顶部和底部内边距为5像素,左右两侧内边距为0像素
padding:5px 10px 3px; 表示顶部内边距为5像素,左右两侧内边距为10像素,底部内边距为3像素
padding:5px 10px 3px 3px; 表示顶部内边距为5像素,右侧内边距为10像素,底部内边距为3像素,左侧内边距为3像素
#box {
width: 70px;
margin: 10px;
padding-left: 5px;// 左侧内边距
//padding-right: 5px;// 右侧内边距
//padding-top: 5px;// 顶部内边距
//padding-bottom: 5px;// 底部内边距
}
#box {
width: 70px;
margin: 10px;
padding: 0 0 0 5px;// 左侧内边距
//padding: 0 5px 0 0;// 右侧内边距
//padding: 5px 0 0 0;// 顶部内边距
//padding: 0 0 5px 0;// 底部内边距
}
四、外边距
提示:外边距可以是负值,而且在很多情况下都要使用负值的外边距。
提示:margin属性值赋值规则:
margin:5px; 表示四周外边距为5像素
margin:5px 0; 表示顶部和底部外边距为5像素,左右两侧外边距为0像素
margin:5px 10px 3px; 表示顶部外边距为5像素,左右两侧外边距为10像素,底部外边距为3像素
margin:5px 10px 3px 3px; 表示顶部外边距为5像素,右侧外边距为10像素,底部外边距为3像素,左侧外边距为3像素
#box {
width: 70px;
margin-left: -5px;// 左侧外边距
//margin-right: -5px;// 右侧外边距
//margin-top:-5px;// 顶部外边距
//margin-bottom: 5px;// 底部外边距
}
#box {
width: 70px;
margin: 0 0 0 5px;// 左侧外边距
//margin: 0 5px 0 0;// 右侧外边距
//margin: 5px 0 0 0;// 顶部外边距
//margin: 0 0 5px 0;// 底部外边距
}
|