【CSS】 布局 - 水平 & 垂直对齐

在这里插入图片描述

元素居中对齐

要水平居中对齐一个元素(如

), 可以使用 margin: auto;。
设置到元素的宽度将防止它溢出到容器的边缘。
元素通过指定宽度,并将两边的空外边距平均分配:
在这里插入图片描述

<style>
	.center {
	    margin: auto;
	    width: 60%;
	    border: 3px solid #73AD21;
	    padding: 10px;
	}
</style>
<body>
	<h2>元素居中对齐</h2>
	<p>水平居中块级元素 (如 div), 可以使用 margin: auto;</p>
	<div class="center">
	  <p><b>注意: </b>使用 margin:auto 无法兼容 IE8, 除非 !DOCTYPE 已经声明。</p>
	</div>
</body>

在这里插入图片描述
注意: 如果没有设置 width 属性(或者设置 100%),居中对齐将不起作用。

文本居中对齐

如果仅仅是为了文本在元素内居中对齐,可以使用 text-align: center;
在这里插入图片描述

<style>
	.center {
	    text-align: center;
	    border: 3px solid green;
	}
</style>

<body>
	<h2>文本居中对齐</h2>
	<div class="center">
	  <p>文本居中对齐。</p>
	</div>
</body>

在这里插入图片描述

图片居中对齐

要让图片居中对齐, 可以使用 margin: auto; 并将它放到 块 元素中:

<style>
	img {
	    display: block;
	    margin: 0 auto;
	}
</style>

<body>
	<h2>图片居中对齐</h2>
	<p>要让图片居中对齐, 可以使用 margin: auto; 并将它放到块元素中:</p>
	<img src="//static.runoob.com/images/mix/paris.jpg" alt="Paris" style="width:40%">
</body>

在这里插入图片描述

<style>
	.right {
	    position: absolute;
	    right: 0px;
	    width: 300px;
	    border: 3px solid #73AD21;
	    padding: 10px;
	}
</style>
<body>
	<h2>右对齐</h2>
	<p>以下实例演示了如何使用 position 来实现右对齐:</p>
	<div class="right">
	  <p>IT -- 学的不仅是技术,更是梦想!!</p>
	</div>
</body>

在这里插入图片描述
注释:绝对定位元素会被从正常流中删除,并且能够交叠元素。
提示: 当使用 position 来对齐元素时, 通常 元素会设置 margin 和 padding 。 这样可以避免在不同的浏览器中出现可见的差异。
当使用 position 属性时,IE8 以及更早的版本存在一个问题。如果容器元素(在我们的案例中是

)设置了指定的宽度,并且省略了 !DOCTYPE 声明,那么 IE8 以及更早的版本会在右侧增加 17px 的外边距。这似乎是为滚动条预留的空间。当使用 position 属性时,请始终设置 !DOCTYPE 声明:

<style>
	body {
	    margin: 0;
	    padding: 0;
	}
	.container {
	    position: relative;
	    width: 100%;
	}
	 .right {
	    position: absolute;
	    right: 0px;
	    width: 300px;
	    background-color: #b0e0e6;
	}
</style>
<body>
	<div class="container">
		<div class="right">
		<p><b>注意: </b>当使用浮动属性对齐,总是包括 !DOCTYPE 声明!如果丢失,它将会在 IE 浏览器产生奇怪的结果。</p>
		</div>
	</div>
</body>

在这里插入图片描述

左右对齐 - 使用 float 方式

我们也可以使用 float 属性来对齐元素:

<style>
	.right {
	    float: right;
	    width: 300px;
	    border: 3px solid #73AD21;
	    padding: 10px;
	}
</style>
<body>
	<h2>右对齐</h2>
	<p>以下实例演示了使用 float 属性来实现右对齐:</p>
	<div class="right">
	  <p>我老爹在小时候给我的一些人生建议,我现在还记忆深刻。</p>
	</div>
</body>

在这里插入图片描述
当像这样对齐元素时,对 元素的外边距和内边距进行预定义是一个好主意。这样可以避免在不同的浏览器中出现可见的差异。
在这里插入图片描述
我们可以在父元素上添加 overflow: auto; 来解决子元素溢出的问题:

<style>
	div {
	    border: 3px solid #4CAF50;
	    padding: 5px;
	}
	
	.img1 {
	    float: right;
	}
	
	.clearfix {
	    overflow: auto;
	}
	
	.img2 {
	    float: right;
	}
</style>
<body>
	<p>以下实例图在父元素中溢出,很不美观:</p>
	<div>
	<img class="img1" src="pineapple.jpg" alt="Pineapple" width="170" height="170">
	IT - 学的不仅是技术,更是梦想!!!</div>
	
	<p style="clear:right">在父元素上通过添加 clearfix 类,并设置 overflow: auto; 来解决该问题:</p>
	
	<div class="clearfix">
	<img class="img2" src="pineapple.jpg" alt="Pineapple" width="170" height="170">
	IT - 学的不仅是技术,更是梦想!!!</div>

</body>

在这里插入图片描述
当使用 float 属性时,IE8 以及更早的版本存在一个问题。如果省略 !DOCTYPE 声明,那么 IE8 以及更早的版本会在右侧增加 17px 的外边距。这似乎是为滚动条预留的空间。当使用 float 属性时,请始终设置 !DOCTYPE 声明:

<style>
	body {
	    margin: 0;
	    padding: 0;
	}
	 
	.right {
	    float: right;
	    width: 300px;
	    background-color: #b0e0e6;
	}
</style>
<body>
	<div class="right">
	<p><b>注意: </b>当使用浮动属性对齐,总是包括 !DOCTYPE 声明!如果丢失,它将会在 IE 浏览器产生奇怪的结果。</p>
	</div>
</body>

在这里插入图片描述

垂直居中对齐 - 使用 padding

CSS 中有很多方式可以实现垂直居中对齐。 一个简单的方式就是头部顶部使用 padding:
在这里插入图片描述

<style>
	.center {
	    padding: 70px 0;
	    border: 3px solid green;
	}
</style>
<body>
	<h2>垂直居中</h2>
	<p>以上实例,我们使用 padding 属性实现元素的垂直居中:</p>
	
	<div class="center">
	  <p>我是垂直居中的。</p>
	</div>
</body>

如果要水平和垂直都居中,可以使用 padding 和 text-align: center:
在这里插入图片描述

<style>
	.center {
	    padding: 70px 0;
	    border: 3px solid green;
	    text-align: center;
	}
</style>
<body>
	<h2>Centering</h2>
	<p>以下实例,我们使用 padding 和 text-align 让 div 元素的水平和垂直方向都居中:</p>
	<div class="center">
	  <p>我是水平和垂直都居中的。</p>
	</div>
</body>

垂直居中 - 使用 line-height

在这里插入图片描述

<style>
	.center {
	    line-height: 200px;
	    height: 200px;
	    border: 3px solid green;
	    text-align: center;
	}
	
	.center p {
	    line-height: 1.5;
	    display: inline-block;
	    vertical-align: middle;
	}
</style>
<body>
	<h2>居中</h2>
	<p>以下实例中,我们让 line-height 属性值和 height 属性值相等来设置 div 元素居中:</p>
	<div class="center">
	  <p>我是垂直居中的。</p>
	</div>
</body>

垂直居中 - 使用 position 和 transform

除了使用 padding 和 line-height 属性外,我们还可以使用 transform 属性来设置垂直居中:

<style>
	.center { 
	    height: 200px;
	    position: relative;
	    border: 3px solid green; 
	}

	.center p {
	    margin: 0;
	    position: absolute;
	    top: 50%;
	    left: 50%;
	    -ms-transform: translate(-50%, -50%);
	    transform: translate(-50%, -50%);
	}
</style>
<body>

	<h2>居中</h2>
	<p>以下实例中,我们使用了 positioning 和 transform 属性来设置水平和垂直居中:</p>
	
	<div class="center">
	  <p>我是水平和垂直居中的。</p>
	</div>
	
	<p>注意: IE8 及更早版本不支持 transform 属性。</p>
</body>

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值