您现在的位置: 365建站网 > 365文章 > div+css图片居中(水平居中和垂直居中)的设置方法

div+css图片居中(水平居中和垂直居中)的设置方法

文章来源:365jz.com     点击数:578    更新时间:2018-01-09 11:05   参与评论
 css图片水平居中

利用margin: 0 auto实现图片水平居中

利用margin: 0 auto实现图片居中就是在图片上加上css样式margin: 0 auto 如下:

<div style="text-align: center; width: 500px; border: green solid 1px;">
<img alt="" src="https://www.baidu.com/img/baidu_jgylogo3.gif" style="margin: 0 auto;" />
</div>


利用文本的水平居中属性text-align: center

代码如下:

<div style="text-align: center; width: 500px; border: green solid 1px;">
<img alt="" src="https://www.baidu.com/img/baidu_jgylogo3.gif" style="display: inline-block;" />
</div>


css图片垂直居中

利用高==行高实现图片垂直居中

这种方法是要知道高度才可以使用,代码如下:

<div style="text-align: center; width: 500px;height:200px; line-height:200px; border: green solid 1px;">
   <img alt="" src="https://www.baidu.com/img/baidu_jgylogo3.gif" style="display: inline-block; vertical-align: middle;" />
</div>


利用table实现图片垂直居中

利用table的方法是利用了table的垂直居中属性,代码如下:

这里使用display: table;和display: table-cell;来模拟table,这种方法并不兼容IE6/IE7,IE67不支持display: table,如果你不需要支持IE67那就可以用

缺点:当你设置了display: table;可能会改变你的原有布局

<div style="text-align: center; width: 500px;height:200px; display: table;border: green solid 1px;">
<span style="display: table-cell; vertical-align: middle; "><img alt="" src="https://www.baidu.com/img/baidu_jgylogo3.gif" style="display: inline-block;" /></span>
</div>


利用绝对定位实现图片垂直居中

如果已知图片的宽度和高度可以这样,代码如下:

<div style="width: 500px;height:200px; position: relative; border: green solid 1px;">
<img alt="" src="https://www.baidu.com/img/baidu_jgylogo3.gif" style="width: 120px; height: 40px;position: absolute; left:50%; top: 50%; margin-left: -60px;margin-top: -20px;" />
</div>


移动端可以利用flex布局实现css图片垂直居中

移动端一般浏览器版本都比较高,所以可以大胆的使用flex布局,(flex布局参考css3的flex布局用法)演示代码如下:

css代码:

<style type="text/css">
/*web前端开发http://www.51xuediannao.com/*/
        .ui-flex {
            display: -webkit-box !important;
            display: -webkit-flex !important;
            display: -ms-flexbox !important;
            display: flex !important;
            -webkit-flex-wrap: wrap;
            -ms-flex-wrap: wrap;
            flex-wrap: wrap
        }

        .ui-flex, .ui-flex *, .ui-flex :after, .ui-flex :before {
            box-sizing: border-box
        }

        .ui-flex.justify-center {
            -webkit-box-pack: center;
            -webkit-justify-content: center;
            -ms-flex-pack: center;
            justify-content: center
        }
        .ui-flex.center {
            -webkit-box-pack: center;
            -webkit-justify-content: center;
            -ms-flex-pack: center;
            justify-content: center;
            -webkit-box-align: center;
            -webkit-align-items: center;
            -ms-flex-align: center;
            align-items: center
        }
    </style>

html代码:

<div class="ui-flex justify-center center" style="border: green solid 1px; width: 500px; height: 200px;">
    <div class="cell">
<img alt="" src="https://www.baidu.com/img/baidu_jgylogo3.gif" style="" />
    </div>
</div>

图片水平垂直居中存在的问题

所谓的图片水平垂直居中就是把图片放在一个容器元素中(容器大于图片尺寸或是指定了大小的容器),并且图片位居此容器正中间(中间是指元素容器的正中间),而图片不是以背景图片(background-image)形式展示,是以<img>元素形式展示的。如下图所示:

大家都知道,如果其中img有明确的尺寸,并且图片尺寸都是一致的,要实现其水平垂直居中一件非常容易的事情,我们只要像下面操作就能方便解决问题:

  1. 将图片以块元素方式显示(display:block);
  2. 给图片指定明确的margin-left和margin-top值,而其中margin-left值等于图片所在容器的宽度(imbBoxWidth)减去图片本身宽度(imgWidth)的值的一半【margin-left=(imgBoxWidth-imgWidth)/2】;margin-top值和margin-left很类似,只是把相对应的宽度值换成高度值,即【margin-top=(imgBoxHeight-imgHeight)/2】。

上面的方法是方便简单,但受限太大,比如说图片不一样时,用上面的方法实现就比较难,或许你会说给相图尺寸的图片定义一个类,然后在给他们指定不同的margin。但有很多情况下我们是无法使用这种方法来解决图片水平垂直居中的问题,比如说有很多不同尺寸的图片,而且图片容器的单位和图片大小单位不一致时,这样我们就没有办法能计算出图片与容器之间的margin是多少,此时解决图片水平居垂直居中就相当的困难。换过来说,如果有什么办法能让不同尺寸的图片实现水平垂直居中,那对于我们来说是多么有用的,又是多么方便的一件事。

解决问题——让图片水平垂直居中

解决水平居中是相当的容易,如果图片左浮动并且"display:inline"时,我们只要给图片设置一个"text-align:center"属性,就顺利解决了水平居中。

对于垂直居中的最佳解决方案,在现代浏览器中,我们可以给图片容器设置“dipslay:table-cell;vertical-align:middle”, 这种方法能顺利的让图片实现垂直居中,但只能在现代浏览器运行,在IE6-7中无法正常运。这样一来是不是将无法实现呢?大家别急,我们一起来看下面的几种方法:

1、table-cell加上display:inline

这种方法很神奇,前面我们说过用display-table和vertical-middle是在现代浏览器中实现图片垂直居中是最佳办法,只是IE6-7不支持display:table-cell,其实并不是那么严重,我们只要在IE6-7下给他来个另外的写法。其实掌握了原理在IE下实现起来也并不难,下面我们一起先来看看这个思路:

  1. 首先在图片的容器元素中设置“display:table-cell;vertical-align:middle;”实现现浏览器的垂直居中;
  2. IE6-7有一个好的办法,就是创建一个线盒,此线盒的高度和图片容器的高度一样,并且给这个线盒也设置“vertical-align:middle”。

接下来的关键是给IE6-7创建线盒,还好IE6-7下部分显示支持“dipslay:inline-block”。这样我们就可以在图片的容器中创建一个空元素(比如说span),并且设置span的“display:inline-block;height:100%;vertical-align:middle”。

创建线盒中有一个细节需要注意,在IE6-7中空的line-block元素宽度为“0”,这样在IE6-7下是没有效果的,此时我们需要给span加上“width:1px”,此时会给水平居中造成1px的误差,但这种bug你是可以接受得了的。

那么最终解决方案就是使用display:table-cell和设置了display:inline-block的线合span。当然其中还是需要为IE写一点特殊的代码,接下来我们的起来看代码:

HTML Markup

<ul class="imgWrap clearfix">
    <li><a href="#" class="imgBox"><span></span><img src="images/img1.jpg" alt="" /></a></li>
    <li><a href="#" class="imgBox"><span></span><img src="images/img2.jpg" alt="" /></a></li>
    <li><a href="#" class="imgBox"><span></span><img src="images/img3.jpg" alt="" /></a></li>
    <li><a href="#" class="imgBox"><span></span><img src="images/img4.jpg" alt="" /></a></li> 
</ul>
		

CSS Code

<style type="text/css">
    .imgWrap li {
     float: left;
     border: solid 1px #666;
     margin: 10px 10px 0 0;
     list-style: none;
     border-collapse: collapse;
    }
    .imgWrap a {
     background: #ffa url(images/gridBg.gif) repeat center;
     width: 219px;
     height: 219px;
     display: table-cell;/*图片容器以表格的单元格形式显示*/
     text-align: center; /* 实现水平居中 */
     vertical-align: middle; /*实现垂直居中*/    
    }
    .imgWrap a:hover {
     background-color: #dfd;
    }
    .imgWrap img {
     border: solid 1px #66f;
     vertical-align: middle; /*图片垂直居中*/
    }
    </style>
    <!--下面是解决IE6-7的正常显示的代码-->
    <!--[if lt IE 8]>
     <style type="text/css">
     .imgWrap a {
      display: block;
     }
     .imgWrap span {
      display: inline-block;
      vertical-align: middle;
      height: 100%;
     }
     .imgWrap {
      _height: 0;
      zoom: 1;
     }
</style>
    <![endif]-->
		

2、空白标签实现图片的垂直居中

这种方法很有意思,也很有独特之处,主要使用了一张宽度为1px高度为100%的透明图片,并设置图片“vertical-align:middle”。后来我想了想,此处能不能不使用图片,直接像上面的实例一样,用一个空格的span标签,只是将其“display:inline”设置为“display:inline-block”。因为这两者的核心原理都是一致的:我将span行内元素设置为行内块元素,也就是将其display设置为“inline-block”,将其宽度定位1px,height为容器的100%,这样高度可以和容器的高度达到一样,然后通过“vertical-align:middle”设置垂直对齐,从而实现所需要的效果。下面一起看看这种方法吧。

HTML Markup

<ul class="imgWrap clearfix">
    <li><a href="#" class="imgBox"><span></span><img src="images/img1.jpg" alt="" /></a></li>
    <li><a href="#" class="imgBox"><span></span><img src="images/img2.jpg" alt="" /></a></li>
    <li><a href="#" class="imgBox"><span></span><img src="images/img3.jpg" alt="" /></a></li>
    <li><a href="#" class="imgBox"><span></span><img src="images/img4.jpg" alt="" /></a></li>
</ul>
		

CSS Code

<style type="text/css">
.imgWrap li{
     width: 219px;
     height: 219px;
     float: left;
     border: solid 1px #666;
     margin: 10px 10px 0 0;
     list-style: none;
     text-align: center;
     font-size: 0;
    }

.imgWrap a {
     display: block;
     height: 100%;
     background: #ffa url(images/gridBg.gif) repeat center;
    }
.imgWrap a:hover {
     background-color: green;
    }
.imgWrap span {
     display: inline-block;/*将行内元素改变为行内块元素显示*/
     width: 1px;/*实现IE下可读效果*/
     height: 100%;/*使用元素高度和图片容器高度一样*/
     vertical-align: middle;/*垂直对齐*/
    }

.imgWrap img {
     vertical-align: middle;
    }
</style>
		

3、display:table模拟表格实现图片垂直居中

接下来要说的这种方法是结构有点复杂,而且在IE6-7事要配合hack来产现。这个方法就是模拟表格的形式来实现图片垂直居中的效果。

表格大家都知道,他有行(table-row)单元格(table-cell),众所周知,表格单元格中“vertical-align: middle”能让元素垂直居中,那么下面这个实例就是利用这种原理来制作的,一起来看代码

HTML Markup

<ul class="imgWrap clearfix">
    <li>
     <div class="table">
      <div class="tableCell">
       <a href="#" class="imgBox"><img src="images/img1.jpg" alt="" /></a>
      </div>
     </div>
    </li>
    <li>
     <div class="table">
      <div class="tableCell">
       <a href="#" class="imgBox"><img src="images/img2.jpg" alt="" /></a>
      </div>
     </div>
    </li>
    <li>
     <div class="table">
      <div class="tableCell">
       <a href="#" class="imgBox"><img src="images/img3.jpg" alt="" /></a>
      </div>
     </div>
    </li>
    <li>
     <div class="table">
      <div class="tableCell">
       <a href="#" class="imgBox"><img src="images/img4.jpg" alt="" /></a>
      </div>
     </div>
    </li>
</ul> 
		

CSS Code

.imgWrap li {
    background: #ffa url(images/gridBg.gif) repeat center;
    width: 219px;
    height: 219px;
    float: left;
    border: solid 1px #666;
    margin: 10px 10px 0 0;
    list-style: none;
    text-align: center;
   }
.table {
    width: 100%;
    height: 100%;
    display: table;
    position: relative;
   } 

.tableCell {   
    display: table-cell;
    vertical-align: middle;
    text-align: center;  
    padding: 10px;
    *position: absolute;
    *top: 50%;
    *left: 50%;
   }
.imgWrap a {
    display: block;
    *position:relative;
    *top: -50%;
    *left: -50%;
   }
		

 

4、jQuery方法实现图片居中

这个方法很简单,就是得用jQuery方法,将图片转换为其父元素的背景图片,并且在其父元素中居中显示背景图片,然后在将其自身的透明度设置为“0”, 这样也能达到图片居中的效果。

Html Markup

<ul class="imgWrap clearfix">
    <li><a href="#" class="imgBox"><img src="images/img1.jpg" alt="" /></a></li>
    <li><a href="#" class="imgBox"><img src="images/img2.jpg" alt="" /></a></li>
    <li><a href="#" class="imgBox"><img src="images/img3.jpg" alt="" /></a></li>
    <li><a href="#" class="imgBox"><img src="images/img4.jpg" alt="" /></a></li>
</ul>

CSS Code

.imgWrap li {
    float: left;
    border: solid 1px #666;
    margin: 10px 10px 0 0;
    list-style: none;
    background: #ffa url(images/gridBg.gif) repeat center;
   }
.imgWrap a {
    width: 219px;
    height: 219px;
    display: block;
   }
		

jQuery Code

//先写一个小插件
   $.fn.imgVAlign=function(){
    return $(this).each(function(i){
     //获取图片的src值,并定义给变量bg
     var bg = $(this).attr("src");
     //给图片的父元素定义背景图片的样式,并且背景图片
     $(this).parent().css({"background": "url("+ bg +") no-repeat center center"
     });
     //将图片隐藏
     $(this).css("opacity","0");
    });
   }
   //调用上面写的插件
   $(document).ready(function(){
    $(".imgBox img").imgVAlign();
   });
		

如对本文有疑问,请提交到交流论坛,广大热心网友会为你解答!! 点击进入论坛

发表评论 (578人查看0条评论)
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
昵称:
最新评论
------分隔线----------------------------

快速入口

· 365软件
· 杰创官网
· 建站工具
· 网站大全

其它栏目

· 建站教程
· 365学习

业务咨询

· 技术支持
· 服务时间:9:00-18:00
365建站网二维码

Powered by 365建站网 RSS地图 HTML地图

copyright © 2013-2024 版权所有 鄂ICP备17013400号