【WEB学习】Day07 - 盒子模型
文章目录
页面布局要学习三大核心:盒子模型、浮动、定位。
一、盒子模型
1.1 网页布局的本质
网页布局的过程,本质上是这样的:
1.先准备好相关的网页元素,网页元素基本上都是盒子(Box)。
2.利用 CSS 设置好盒子样式,然后摆放到相应位置。
3.往盒子里装内容。
因此网页布局的核心就是:利用 CSS 摆盒子。
1.2 盒子模型(Box Model)组成
CSS 盒子模型就是把 HTML 页面中的布局元素看作是一个矩形的盒子,也就是一个盛装内容的容器。它包括一些要素:边框(Border)、外边距(Margin)、内边距(Paddding)、实际内容(Content)。
1.3 边框(Border)
一个完整的边框由三部分组成:边框宽度(粗细)、边框样式、边框颜色。
border: border-width || border-style || border-color
常见的边框样式有:实线(solid)、虚线(dashed)、点线(dotted)等。
以上三种属性可以用边框的复合性写法:
border: 1px solid red; /* 没有顺序 */
边框也可以分成四条边分别设定样式:
border-top: 1px solid red; /* 只设定上边框,其余同理 */
border-bottom: 10px dashed purple;
border-left: 30px solid blue;
border-right: 20px dotted red;
在独立设定四条边时,可以覆盖直接设定的内容(CSS层叠性),比如要写一个只有顶边是红色的蓝色矩形,可以先用border设定所有边框为蓝色,再用border-top设定顶边为红色(但是不可以顺序反过来,因为就近原则,后写的会覆盖上一个):
<style>
div {
border: 1px solid blue;
border-top: 1px solid red;
}
</style>
1.4 表格的细线边框
在制作数据表格时,我们要给 table 和 td 都加上边框。
<style>
table,
td {
border: 1px solid black;
}
</style>
当两个单元格都有边框时它们中间的线就会看起来非常厚(2px),因此,想要实现表格内部的细线,需要引入其他标签。
border-collapse 属性控制浏览器绘制表格边框的方式。它控制相邻单元格的边框。语法:
border-collapse: collapse;
想要把边框合并,只需要这样:
<style>
table,
td {
border: 1px solid black;
/* 合并相邻的边框 */
border-collapse: collapse;
}
</style>
1.5 边框会影响盒子的实际大小
假如我们需要一个200*200的盒子,但是这个盒子有10px的边框,那么实际上这个盒子是220px * 220px。因此我们在测量时:
1.测量盒子大小的时候,不要量边框。
2.测量整个大小,然后用 width/height 减去边框宽度。
1.6 内边距(Padding)
padding 属性用于设置内边距,即边框与内容之间的距离。单位仍然是px。
内边距可以用复合性写法(简写属性),可以有一到四个值:
padding也会影响盒子大小!!
一个 200*200 像素的盒子,如果内边距有了值,也会撑大盒子,所以要注意这一点,在测量时,先测出盒子的总大小,然后减去多出来的内边距大小。
但是也有例外情况,如果盒子本身没有指定 width / height 属性,则此时 padding 不会撑开盒子大小。
1.7 外边距(Margin)
margin 属性用于设置外边距,控制盒子和盒子之间的距离。
margin 的用法和 padding 类似,也可以分边设置。
<style>
div {
width: 200px;
height: 200px;
background-color: green;
}
.one {
margin-bottom: 10px;
}
.two {
margin-top: 10px;
}
</style>
<body>
<div class="one">1</div>
<div class="two">2</div>
</body>
此时,one 和 two 两个 div 的边距由它们各自提供 10px ,总边距是 20px 。
margin 的简写方式和 padding 也是完全一致的。
将 padding 换成 margin ,一样适用。
margin 一般在使用时,是用来让块级盒子水平居中的,但是必须满足两个条件:
① 盒子必须指定了宽度( width )。
② 盒子左右的外边距都设置为 auto 。
.header { width: 960px; margin: 0 auto; }
常见的写法,以下三种都可以:
- margin-left: auto; margin-right: auto;
- margin: auto;
- margin: 0 auto;
注意:以上方法是让块级元素水平居中,行内元素或者行内块元素水平居中的方法是,给其父元素添加 text-align:center 即可(把这些元素看作是文本)。
<style>
.header {
text-align: center;
}
</style>
<body>
<div class="header">
<span>里面的文字</span>
</div>
<div class="header">
<img src="down.jpg" alt="">
</div>
</body>
这样可以实现 class 名为 “header” 的 div 内部的文字和图片都水平居中。
1.8 外边距合并
使用 margin 定义块元素的垂直外边距时,可能会出现外边距的合并。主要有两种情况:
- 相邻块元素垂直外边距的合并
- 嵌套块元素垂直外边距的塌陷
1.8.1 相邻块元素垂直外边距的合并
当上下相邻的两个块元素(兄弟关系)相遇时,如果上元素有下边距 margin-bottom,下元素有上边距 margin-top,则他们之间的垂直间距不是 margin-bottom 与 margin-top之和。取的是两个值中的较大者,这种现象被称作相邻块元素垂直外边距的合并。
<style>
.one {
margin-bottom: 100px;
}
.two {
margin-top: 200px;
}
</style>
<body>
<div class="one">大哥</div>
<div class="two">二弟</div>
</body>
这样写,大哥和二弟之间的间距不会是300px,而是取二者较大的200px。
1.8.2 嵌套块元素垂直外边距的塌陷
对于两个嵌套关系(父子关系)的块元素,父元素有上外边距同时子元素也有上外边距,此时父元素会塌陷较大的外边距值(只取了较大的外边距值)。解决方案:① 可以为父元素定义上边框。② 可以为父元素定义上内边距。③ 可以为父元素添加 overflow : hidden 。
还有其他方案,比如:浮动、固定、绝对定位的盒子没有塌陷情况。
1.9 清除内外边距
网页元素很多都带有默认的内外边距,不同浏览器默认的也不一致,我们在布局前,要先清除网页元素的内外边距。
* {
padding: 0; /* 清除内边距 */
margin: 0; /* 清除外边距 */
}
注意:行内元素为了照顾兼容性,尽量只设置左右内外边距,不要设置上下内外边距。但是转换为块级和行内块元素就可以设置了。