zoukankan      html  css  js  c++  java
  • css实现垂直水平居中的方法(个数不限)?

    方法一:使用绝对定位

              大家都知道margin:0 auto;能够实现水平居中,但却不知道margin:0 auto;也是可以实现垂直居中的;

    给居中元素添加如下样式:

    .Absolute-Center {
            border:2px solid red;
            height: 200px;
            margin: auto;
            position: absolute;
            top: 0; left: 0; bottom: 0; right: 0;
        }

    缺点:内容容易溢出,建议使用overflow:auto;

    方法二:负margin方法

    给居中的div设置样式:

    <style>
        * {
            margin: 0;
            padding: 0;
        }
    
        .Absolute-Center {
            width: 400px;
            height: 200px;
            background-color: pink;
            position: absolute;
            top: 50%;
            left: 50%;
            margin-top: -100px;
            margin-left: -200px;
        }
    </style>
    <body>
    <div class="Absolute-Center">
    </div>
    </body>

    方法三:css3的 transform 来实现

    <style>
        * {
            margin: 0;
            padding: 0;
        }
        .mydiv {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            width: 300px;
            height: 200px;
        }
    </style>
    <body>
    <div class="mydiv" style="border: 2px solid red;"></div>
    </body>

    http://blog.csdn.net/freshlover/article/details/11579669

     重新整理部分如下:

    CSS实现垂直水平居中的方法(至少写2种)

    (1)      文本的水平垂直居中

    使用:line-height  +  text-align: center

    <div class=”wrap”>

        文本的垂直水平居中

    </div>

    html,body{

      margin: 0;

    }

    .wrap{

      line-height: 400px;

      text-align: center;

     height: 400px;

     font-size:36px;

    }

    (2)      使用margin: auto 方法实现div水平垂直居中

    <div class=”wrap”>

        <div class=”content”></div>

    </div>

    .wrap{

      Position: relative;

      200px;

     height: 300px;

     border: 1px solid red;

    }

    .content{

      Position: absolute;

      50%;

     height: 50%;

    top: 0;

    left: 0;

    right: 0;

    bottom: 0;

    margin: auto;

     border: 1px solid red;

    }

    (3)      负margin方法

    <div class=”wrap”>

        <div class=”content”></div>

    </div>

    .wrap{

      Position: relative;

      200px;

     height: 300px;

     border: 1px solid red;

    }

    .content{

      Position: absolute;

      180px;

     height: 260px;

    top: 50%;

    left: 50%;

    margin-top: -130px;

    margin-left: -90px;

     border: 1px solid red;

    }

    (4)      让图片水平垂直居中,使用table-cell方法

    <div class=”wrap”>

        <img src=”tupian.png”/>

    </div>

    .wrap{

      200px;

     height: 300px;

     border: 1px solid red;

    display:table-cell;

    vertical-align: middle;

    text-align:center;

    }

    img{

      vertical-align:middle;

     border: 1px solid red;

    }

    (5)      弹性盒子方法

    <div class=”wrap”>

        <div class=”content”></div>

    </div>

    .wrap{

      300px;

     height: 200px;

     border: 1px solid red;

    display: -webkit-flex;

    display: flex;

    -webkit-align-items: center;

    align-items: center;

    -webkit-justify-content: center;

    justify-content: center;

    }

    .content{

      padding: 20px;

    border: 1px solid red;

    }

    (6)      使用CSS3的transform:translate(-50%,-50%); 或者

    transform:translate3d(-50%,-50%,0);

     

    <div class=”wrap”>

        <div class=”content”></div>

    </div>

    .wrap{

      300px;

     height: 200px;

     border: 1px solid red;

    position: relative;

    }

    .content{

      Position: absolute;

    160px;

    height: 100px;

    left: 50%;

    right: 50%;

    transform: translate(-50%,-50%);或者用3d旋转的也可以

    }

  • 相关阅读:
    与众不同 windows phone (12) Background Task(后台任务)之 PeriodicTask(周期任务)和 ResourceIntensiveTask(资源密集型任务)
    直观理解图像的傅里叶变换
    简明Python3教程 13.面向对象编程
    简明Python3教程 4.安装
    简明Python3教程 8.控制流
    简明Python3教程 11.数据结构
    简明Python3教程 16.标准库
    简明Python3教程 12.问题解决
    简明Python3教程 9.函数
    简明Python3教程 2.序言
  • 原文地址:https://www.cnblogs.com/phermis/p/7591279.html
Copyright © 2011-2022 走看看