• 技术文章 >web前端 >html教程

    html水平垂直居中的问题

    高洛峰高洛峰2017-02-24 10:41:26原创918
    最近遇到很多居中的问题,就花点时间总结了一下放在这里,以后找也方便

    1.居中文本

    <p class="wrap">
          我在中间……
    </p>
    .. height+line-height+text-center(只能居中单行)
    .wrap{
        width:px; 
        height:px;
        border:px solid red; 
        text-align: center;
        line-height: px;
    }


    ps:text-align:center只是将元素下面的内联元素居中显示
    1.2display:table-cell(多行固定高度居中)

    .wrap{
        width:px; 
        height:px;
        border:px solid red; 
        text-align: center; 
        display:table-cell; 
        vertical-align: middle;
    }
    
    display:table-cell:ie67不管用,最好配合display:table;一起用


    ie67下:(以后也不用了,不过也放这儿吧)
    方法一:(通过em标签高度与父级等高,所以span和em居中就相当于span在父级居中)

    <p class="wrap">
       <span>
           我在中间…… 我在中间…… 我在中间…… 我在中间……
       </span>
       <em></em>
    </p>
     .wrap{
         width:px; 
         height:px;
         border:px solid red; 
         text-align: center;
     }
     .wrap span{
         vertical-align: middle;
         display:inline-block; 
        width:px;
    }
    .wrap em{
        height:%;
        vertical-align: middle; 
        display:inline-block;
    }

    方法二:(通过给子元素增加一个绝对定位的父级标签,再配合子元素的相对定位水平垂直居中)

    <p class="wrap">
        <span class="span">
           <span class="span">我在中间…… 我在中间…… 我在中间…… 我在中间……</span>
        </span>
    </p>
     .wrap{
         width:px; 
         height:px;
         border:px solid red;
         display:table;
         position:relative; 
         overflow: hidden;
     }
     .wrap .span{
        display:table-cell; 
        vertical-align: middle; 
        text-align: center;
        *position:absolute;
        top:%;
        left:%;
    }
    .wrap .span{
        *position:relative;
        top:-%;
        left:-%;
    }


    1.3padding(内填充,不用多说)

    .wrap{
        width:px;
        border:px solid red;
        padding:px ;
    }

    2.居中元素

    <p class="wrap">
        <span></span>
    </p>



    2.1position:absolute+margin负值(必须要有宽高,才能计算margin)

     .wrap{
         width:px; 
         height:px;
         position:absolute; 
         top:%; 
         left:%; 
         margin-top:-px; 
         margin-left:-px;
         border:px solid red;
    }
    .wrap span{ 
        width:px; 
        height:px; 
        background:red;
        position: absolute; 
        top:%; 
        left:%; 
        margin-top:-px; 
        margin-left:-px;
    }


    ps:CSS实现p水平居中和上下垂直居中

    <!DOCTYPE html>  
    <html>  
    <head>  
    <meta charset="utf-8" />  
    <title>上下垂直居中 在线演示 pCSS5</title>  
    <style>  
    #main {  
       position: absolute;  
       width:400px;  
       height:200px;  
       left:50%;  
       top:50%;  
       margin-left:-200px;  
       margin-top:-100px;  
       border:1px solid #00F  
    }  
    /*css注释:为了方便截图,对CSS代码进行换行*/  
    </style>  
    </head>  
    <body>  
       <p id="main">p水平居中和上下垂直居中<a href="http://www.pcss5.com/">pCSS5</a></p>  
    </body>  
    </html>

    水平垂直居中原理介绍
    这里使用了绝对定位position:absolute,使用left和top设置对象距离上和左为50%,但如果设置50%,实际上盒子是没有实现居中效果,所以又设置margin-left:-200px;margin-top:-100px;,这里有个技巧是,margin-left的值是宽度一半,margin-top的值也是对象高度一半,同时设置为负,这样就实现了水平和垂直居中。

    更多html水平垂直居中的问题相关文章请关注PHP中文网!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:HTML常用标签及html标签的特点 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ajax基本介绍• jquery的each,map,has• html +CSS+div学习――第二课_html/css_WEB-ITnose• 使用jQuery实现地址联动• 七个你可能不了解的CSS单位_html/css_WEB-ITnose
    1/1

    PHP中文网