当前位置:Gxlcms > css > css如何实现图片在div中垂直居中

css如何实现图片在div中垂直居中

时间:2021-07-01 10:21:17 帮助过:41人阅读

本文章主要介绍css如何实现图片在div中垂直居中问题,具有一定参考价值,希望能给大家提供帮助

平时我们在做页面时经常会遇到让我们把一张图片显示在div正中间但是常常不知道如何去做,今天我们来分享几种常用的css实现图片在div中垂直居中的代码

HTML代码

  1. <div>
  2. <img src="images/1.jpg">
  3. </div>

方法一

利用position和margin共同实现

通过给父元素设置绝对定位属性来让子元素相对于div定位

relative是保留原来的位置进行定位并且是相对于自己原来的位置进行定位

absolute 是脱离原来位置定位,是相对于最近的有定位的父级进行定位;如果没有有定位的父级元素,就相对于文档进行定位

注意:要使子元素的上下左右都为0,然后设置margin:auto就会自动垂直居中

代码如下

  1. div{
  2. width:200px;
  3. height:200px;
  4. border: 1px solid #ccc;
  5. position: relative;//父元素设置绝对定位
  6. }
  7. img{
  8. position: absolute;//相对定位
  9. width:80px;
  10. height:50px;
  11. top:0;
  12. left:0;
  13. right:0;
  14. bottom:0;
  15. margin:auto;//使其垂直居中
  16. }

效果图

Image 9.jpg

方法二

利用display: table-cell;vertical-align: middle;text-align: center;三种属性实现

display:table-cell:会作为一个表格单元格显示(类似 <td> 和 <th>)

vertical-align: middle;设置垂直对齐方式,适用于行级元素

text-align: center:设置水平对其方式,该属性通过指定行框与哪个点对齐,从而设置块级元素内文本的水平对齐方式。

  1. div{
  2. width:200px;
  3. height: 200px;
  4. margin:300px auto;
  5. display: table-cell;//作为一个表格单元格显示
  6. vertical-align: middle;//设置垂直对齐方式
  7. text-align: center;//设置水平对其方式
  8. border:1px solid #ccc;
  9. }
  10. img {
  11. width:80px;
  12. height:50px;
  13. }

效果图

Image 9.jpg

方法三

利用position,以及margin-top、margin-left实现

在本方法中要注意margin-top、margin-left值的设定,要设置为元素高度和宽度的一半,而且都要取负值

例如margin-top: -40px意思就是元素距离上边界向上40px,而margin-top: 40px的意思是距离上边界元素向下40px

  1. div{
  2. width:200px;
  3. height:200px;
  4. border: 1px solid #ccc;
  5. position: relative;
  6. }
  7. img{
  8. position: absolute;
  9. width:80px;
  10. height: 50px;
  11. top:50%;
  12. left:50%;
  13. margin-top: -40px;//向上40px
  14. margin-left: -25px;//向左25px
  15. }

效果图

Image 9.jpg

总结:实现利用css将图片在div中垂直居中问题的方法有很多中,以上就是我总结出来的三种方法,其余的欢迎大家补充,希望这篇文章能够对大家学习页面布局有所帮助。

以上就是css如何实现图片在div中垂直居中的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行