zoukankan      html  css  js  c++  java
  • CSS让图片垂直居中的几种技巧

    在网页设计过程中,有时候会希望图片垂直居中的情况。而且,需要垂直居中的图片的高度也不确定,这就会给页面的布局带来一定的挑战。下面总结了一下,曾经使用过的几种方法来使图片垂直居中,除了第一种方法只限于标准浏览器外,另外两种方法的兼容性还不错。

    方法一

    将外部容器的显示模式设置成display:table,这个设置的意思不用多说了吧… img标签外部再嵌套一个span标签,并设置span的显示模式为display:table-cell,这样span内部的内容就相当于表格,可以很方便的使用vertical-align属性来对齐其中的内容了。

    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
        <title>方法1 - 未知高度的图片垂直居中 - www.nowamagic.net</title>
    <style type="text/css">
    body {
        height:100%;
    }
    #box{
        width:500px;height:400px;
        display:table;
        text-align:center;
        border:1px solid #d3d3d3;background:#fff;
    }
    #box span{
        display:table-cell;
        vertical-align:middle;
    }
    #box img{
        border:1px solid #ccc;
    }
    </style>
    <!--[if lte IE 7]>
    <style type="text/css">?
    #box{
        position:relative;
        overflow:hidden;
    }
    #box span{
        position:absolute;
        left:50%;top:50%;
    }
    #box img{
        position:relative;
        left:-50%;top:-50%;
    }
    </style>
    <![endif]-->
    
    </head>
    
    <body>
    <div id="box">
        <span><img src="images/demo_zl.png" alt="" /></span>
    </div>
    
    </body>
    </html>

    方法二

    标准浏览器的情况还是和上面一样,不同的是针对IE6/IE7利用在img标签的前面插入一对空标签的办法。

    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
        <title>方法2 - 未知高度的图片垂直居中 - www.nowamagic.net</title>
    
    <style type="text/css">
    body {
        height:100%;
    }
    #box{
    width:500px;height:400px;
    display:table-cell;
    text-align:center;
    vertical-align:middle;
    border:1px solid #d3d3d3;background:#fff;
    }
    #box img{
    border:1px solid #ccc;
    }
    </style>
    <!--[if IE]>
    <style type="text/css">?
    #box i {
        display:inline-block;
        height:100%;
        vertical-align:middle
        }
    #box img {
        vertical-align:middle
        }
    </style>
    <![endif]-->
    
    </head>
    
    <body>
    <div id="box">
        <i></i><img src="images/demo_zl.png" alt="" />
    </div>
    
    </body>
    </html>

    方法三

    在img标签外包裹一个p标签,标准浏览器利用p标签的伪类属性:before来实现居中,另外,对于IE6/IE7使用了CSS表达式来实现兼容。

    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
        <title>方法3 - 未知高度的图片垂直居中 - www.nowamagic.net</title>
    
    <style type="text/css">
    body {
        height:100%;
    }
    #box{
        width:500px;height:400px;
        text-align:center;
        border:1px solid #d3d3d3;background:#fff;
    }
    #box p{
        width:500px;height:400px;
        line-height:400px;  /* 行高等于高度 */
    }
    
    /* 兼容标准浏览器 */
    #box p:before{
        content:".";  /* 具体的值与垂直居中无关,尽可能的节省字符 */
        margin-left:-5px; font-size:10px;  /* 修复居中的小BUG */
        visibility:hidden;  /*设置成隐藏元素*/
    }
    
    #box p img{
        *margin-top:expression((400 - this.height )/2);  /* CSS表达式用来兼容IE6/IE7 */
        vertical-align:middle;
        border:1px solid #ccc;
    }
    </style>
    
    </head>
    
    <body>
    <div id="box">
        <p><img src="images/demo_zl.png" alt="" /></p>
    </div>
    
    </body>
    </html>
  • 相关阅读:
    mybatis之mapper.xml分析
    mybati之运行过程
    ibatis中的resultClass,parameterClass,resultMap,resultType的使用与区别
    mybatis之parameterType传递多个参数
    mybati之#与$的区别
    【Java面试题】20 运行时异常和一般异常有何区别
    【Java面试题】19 final,finally和finalize的区别
    【Java面试题】18 java中数组有没有length()方法?string没有lenght()方法?下面这条语句一共创建了多少个对象:String s="a"+"b"+"c"+"d";
    【Java面试题】17 如何把一个逗号分隔的字符串转换为数组? 关于String类中split方法的使用,超级详细!!!
    【Java面试题】16 静态代码块,main方法,构造代码块,构造方法
  • 原文地址:https://www.cnblogs.com/songchaoke/p/3476116.html
Copyright © 2011-2022 走看看