前端学习笔记-CSS-盒子外边距(margin)

本文详细介绍了CSS中的外边距(margin)属性,包括如何使用margin实现盒子居中,区别文字和图片的居中方式,以及如何清除元素的默认内外边距。此外,还探讨了外边距合并的现象及其解决方案,如相邻块元素和嵌套块元素的垂直外边距合并。同时,文章讲解了content宽度和高度的控制,并强调了盒子模型布局稳定性的策略——优先使用width,其次使用padding,最后使用margin。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

外边距(margin)

margin属性用于设置外边距。 设置外边距会在元素之间创建“空白”, 这段空白通常不能放置其他内容。

margin-top:上外边距

margin-right:右外边距

margin-bottom:下外边距

margin-left:上外边距

margin:上外边距 右外边距 下外边距 左外边

取值顺序跟内边距相同。

 

外边距实现盒子居中

可以让一个盒子实现水平居中,需要满足一下两个条件:

  1. 必须是块级元素。

  2. 盒子必须指定了宽度(width)

然后就给左右的外边距都设置为auto,就可使块级元素水平居中。

实际工作中常用这种方式进行网页布局,示例代码如下:

.header{ width:960px; margin:0 auto;}

 

练习:

<!DOCTYPE html>
<html lang="en">
<head>
	<!-- 
	可以让一个盒子实现水平居中,需要满足一下两个条件:
	1.必须是块级元素。
	2.盒子必须指定了宽度(width)
	 -->
	<meta charset="UTF-8">
	<title>盒子外边距(margin)</title>
	<style>
		div{
			width: 300px;
			height: 300px;
			background: pink;
			text-align: center;/*盒子里面的内容水平居中*/
			line-height: 300px;/*盒子里面的内容垂直居中*/
			margin: 0 auto;/*盒子水平居中,常规写法 auto相当于是充满的意思*/
			/*margin: auto;   盒子水平居中,上下左右都为auto,上下auto不解析,因此相当于是只取左右auto*/
			/*margin-left: auto;
			margin-right: auto;
			左右两边分别充满,盒子保持居中*/
		}
	</style>
</head>
<body>
	<div>盒子居中</div>
</body>
</html>

效果:

 

文字盒子居中 图片和背景区别

  1. 文字水平居中是 text-align: center

  2. 盒子水平居中 左右margin 改为 auto

text-align: center; /*  文字居中水平 */
margin: 10px auto;  /* 盒子水平居中  左右margin 改为 auto 就阔以了 */
  1. 插入图片 我们用的最多 比如产品展示类

  2. 背景图片我们一般用于小图标背景 或者 超大背景图片

section img {  
        width: 200px;/* 插入图片更改大小 width 和 height */
        height: 210px;
        margin-top: 30px;  /* 插入图片更改位置 可以用margin 或padding  盒模型 */
        margin-left: 50px; /* 插入当图片也是一个盒子 */
    }
​
aside {
        width: 400px;
        height: 400px;
        border: 1px solid purple;
        background: #fff url(images/sun.jpg) no-repeat;
    
        background-size: 200px 210px; /*  背景图片更改大小只能用 background-size */
        background-position: 30px 50px; /* 背景图片更该位置 我用 background-position */
    }

 

清除元素的默认内外边距

为了更方便地控制网页中的元素,制作网页时,可使用如下代码清除元素的默认内外边距(尽量使用指定标签清除内外边距的写法,使用*写法,游览器解析较慢):

* {
   padding:0;         /* 清除内边距 */
   margin:0;          /* 清除外边距 */
}



body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, p, blockquote, th, td { margin:0; padding:0; }

注意: 行内元素是只有左右外边距的,是没有上下外边距的。 内边距,在ie6等低版本浏览器也会有问题。

我们尽量不要给行内元素指定上下的内外边距就好了。

 

外边距合并

使用margin定义块元素的垂直外边距时,可能会出现外边距的合并。

相邻块元素垂直外边距的合并

当上下相邻的两个块元素相遇时,如果上面的元素有下外边距margin-bottom下面的元素有上外边距margin-top,则他们之间的垂直间距不是margin-bottom与margin-top之和,而是两者中的较大者。这种现象被称为相邻块元素垂直外边距的合并(也称外边距塌陷)。

 

解决方案: 避免就好了。

嵌套块元素垂直外边距的合并

对于两个嵌套关系的块元素,如果父元素没有上内边距及边框,则父元素的上外边距会与子元素的上外边距发生合并(即:当子元素定义一个上外边距想与父元素保持距离时,父元素会跟随着子元素,整体位置下移),合并后的外边距为两者中的较大者,即使父元素的上外边距为0,也会发生合并。

举例:

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>外边距的合并</title>
	<style>
	.father {
		width: 500px;
		height: 500px;
		background-color: pink;
        /*解决方法:*/
		/*padding-top: 50px;*/
		/*border-top: 1px solid pink; 1. 用border 会撑大盒子*/ 
		/*padding-top: 1px;           2 用padding 会撑大盒子 */
		overflow: hidden;  /*         3. 用这个单词可以解决 不会撑大盒子*/
	}
	.son {
		width: 200px;
		height: 200px;
		background-color: purple;
		margin-top: 50px;/*垂直存在存在外边距的合并的问题*/
		margin-left: 50px;/*水平不存在外边距的合并的问题*/
	}
	</style>
</head>
<body>
	<div class="father">
		<div class="son"></div>
	</div>
</body>
</html>

 

解决方案:

  1. 可以为父元素定义1像素的上边框或上内边距。

  2. 可以为父元素添加overflow:hidden。

 

content宽度和高度

使用宽度属性width和高度属性height可以对盒子的大小进行控制。

width和height的属性值可以为不同单位的数值或相对于父元素的百分比%,实际工作中最常用的是像素值。

大多数浏览器,如Firefox、IE6及以上版本都采用了W3C规范,符合CSS规范的盒子模型的总宽度和总高度的计算原则是:

  /*外盒尺寸计算(元素空间尺寸)*/
  Element空间高度 = content height + padding + border + margin
  Element 空间宽度 = content width + padding + border + margin
  /*内盒尺寸计算(元素实际大小)*/
  Element Height = content height + padding + border (Height为内容高度)
  Element Width = content width + padding + border (Width为内容宽度)

注意:

1、宽度属性width和高度属性height仅适用于块级元素,对行内元素无效( img 标签和 input除外)。

2、计算盒子模型的总高度时,还应考虑上下两个盒子垂直外边距合并的情况。

3、如果一个盒子则会和父亲一样宽 占满父亲的宽度, 如果此盒子没有给定宽度 则padding 不会影响本盒子大小

 

盒子模型布局稳定性

按照 优先使用 宽度 (width) 其次 使用内边距(padding) 再次 外边距(margin)。

  width >  padding  >   margin   

原因:

  1. margin 会有外边距合并 还有 ie6下面margin 加倍的bug(讨厌)所以最后使用。

  2. padding 会影响盒子大小, 需要进行加减计算(麻烦) 其次使用。

  3. width 没有问题(嗨皮)我们经常使用宽度剩余法 高度剩余法来做。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值