• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    关于html水平垂直居中的问题小结

    最近遇到很多居中的问题,就花点时间总结了一下放在这里,以后找也方便

    1.居中文本

    复制代码
    代码如下:

    <div class="wrap">
    我在中间……
    </div>
    .. 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在父级居中)
     
    复制代码
    代码如下:

    <div class="wrap">
    <span>
    我在中间…… 我在中间…… 我在中间…… 我在中间……
    </span>
    <em></em>
    </div>
    .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;
    }

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

    复制代码
    代码如下:

    <div class="wrap">
    <span class="span">
    <span class="span">我在中间…… 我在中间…… 我在中间…… 我在中间……</span>
    </span>
    </div>
    .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.居中元素

    复制代码
    代码如下:

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

    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实现DIV水平居中和上下垂直居中

    复制代码
    代码如下:

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8" />
    <title>上下垂直居中 在线演示 DIVCSS5</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>
    <div id="main">DIV水平居中和上下垂直居中<a href="http://www.divcss5.com/">DIVCSS5</a></div>
    </body>
    </html>

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

    上一篇:HTML设计模式日常学习笔记整理
    下一篇:HTML常用标签大全及html标签的特点
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    关于html水平垂直居中的问题小结 关于,html,水平,垂直,居,