【WEB学习】Day07 - 盒子模型

【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;    /* 清除外边距 */
}

注意:行内元素为了照顾兼容性,尽量只设置左右内外边距,不要设置上下内外边距。但是转换为块级和行内块元素就可以设置了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值