zoukankan      html  css  js  c++  java
  • css3水平垂直居中(不知道宽高同样适用)

    css水平垂直居中

    第一种方法:

       在父div里加:

          display: table-cell;
          vertical-align: middle;
          text-align: center;
    

       内部div设置: 

        display: inline-block;

       代码如下:

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>css水平垂直居中</title>
        <style>
            body {
                margin: 0;
            }
    
            .center {
                width: 250px;
                height: 250px;
                border: 2px solid red;
                font-size: 18px;
    
                /* 方法1 */
                display: table-cell;
                vertical-align: middle;
                text-align: center;
            }
    
            .center_inner {
                width: 100px;
                height: 100px;
                background-color: pink;
                
                /* 方法1 */
                display: inline-block;
            } 
        </style>
    </head>
    
    <body>
        <div class="center">
            <div class="center_inner">面朝大海,春暖花开!</div>
            <!-- <div class="center_inner center_last">海阔天空</div> -->
        </div>
    </body>
    
    </html>
      使父元素内的所有行内元素水平垂直居中(内部div设置display:inline-block即可)。

    中间的粉色是居中的div

      

      若子元素是图像,可不使用table-cell,而是其父元素用行高替代高度,且字体大小设为0。子元素本身设置vertical-align:middle

     

    <style>
        .f12 .parent{
            line-height: 200px;
            text-align: center;
            font-size:0;
        }
        .f12 .child{
            vertical-align: middle;
        }
    </style>
    <div class="case-box f12" data-case="f12">
        <div class="parent" style=" 200px;">
            <img class="child" src="../../img/head.jpg" style="50px;" alt="test">
        </div>
    </div>

     展示效果为把div改为图片

    第二种方法:

       在居中的div元素里加

       /* 第二种方法 */
                position: absolute;
                top: 50%;
                left: 50%;
                transform:translate(-50%,-50%);

       代码如下:

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>css水平垂直居中</title>
        <style>
            .center {
                width: 100px;
                height: 100px;
                background-color: pink;
                /* 第二种方法 */
                position: absolute;
                top: 50%;
                left: 50%;
                transform:translate(-50%,-50%);
            }
        </style>
    </head>
    <body>
        <div class="center">海阔天空</div>
    </body>
    
    </html>

        translate()函数可以在不知道宽高的情况下,利用它实现水平垂直居中。

        translate(-50%, -50%)作用是,往上(X轴),左(Y轴)移动自身长度的50%,以使其居于中心位置。

        如果使用top:50%, left:50%,是以左上角为原点,故不处于中心位置;但如果知道宽高,可以

                position: absolute;
                top: 50%;
                left: 50%;
                margin-left: -50px;
                margin-top: -50px;            

    第三种方法:用弹性布局实现垂直左右居中

    display:flex; 设置.wrap为弹性布局
    
    justify-content:center;定义项目在主轴(水平方向)上居中对齐
    
    align-items:center;定义项目在交叉轴(垂直方向)上居中对齐

      代码如下:

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>css水平垂直居中</title>
        <style>
            * {
                margin: 0;
                padding: 0;
            }
    
            .center {
                width: 200px;
                height: 200px;
                border: 2px solid red;
                margin:40px;
                display: flex;
                justify-content: center;
                align-items: center;
            }
    
            .inner {
                width: 50px;
                height: 50px;
                background-color: pink;
            }
        </style>
    </head>
    
    <body>
        <div class="center">
            <div class="inner">朝气蓬勃</div>
        </div>
    </body>
    
    </html>

      效果图:

       如果想让里面的文字也水平垂直居中,在粉红色背景的div加上下面的css属性

        display: flex;
        align-items: center;
        justify-content: center;

    第四种方法:绝对定位

      在父div里加

    position: relative;

      在子div里加

        position: absolute;
        top:0;
        left:0;
        right: 0;
        bottom: 0;
        margin: auto;

      代码如下:

    <!DOCTYPE html>
    <html lang="en">

    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>test</title>
        <style>
            #box {
                 250px;
                height: 250px;
                background-color: pink;
                position: relative;
            }

            .inner {
                 100px;
                height: 100px;
                background-color: red;

                top: 0;
                left: 0;
                right: 0;
                bottom: 0;
                margin: auto;
            }
        </style>
    </head>

    <body>
        <div id="box" title="风度翩翩">
            <div class="inner">胆识超群</div>
        </div>
    </body>

    </html>

      效果如下:

      

    第五种方法:

      在父div里加:

        display:table-cell;
        vertical-align: middle;    

      在子div里加:

       display: table;
       margin: 0 auto;

      代码如下: 

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>test</title>
        <style>
            #box {
                width: 250px;
                height: 250px;
                background-color: blue;
                display: table-cell;
                vertical-align: middle;
            }
    
            .inner {
                width: 100px;
                height: 100px;
                background-color: red;
    
                display: table;
                margin: 0 auto;
            }
        </style>
    </head>
    
    <body>
        <div id="box" title="风度翩翩">
            <div class="inner">明眸皓齿</div>
        </div>
    </body>
    
    </html>

      效果如下:

      

     第六种:flex

      在父元素里加

      display: flex;

      在子元素里加:

      margin:auto;

      代码如下: 

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>test</title>
        <style>
            #box {
                width: 250px;
                height: 250px;
                background-color: yellow;
                display: flex;
            }
    
            .inner {
                width: 100px;
                height: 100px;
                background-color: red;
    
                margin: auto;
            }
        </style>
    </head>
    
    <body>
        <div id="box" title="豁达大度">
            <div class="inner">才华横溢</div>
        </div>
    </body>
    
    </html>

      效果如下:

      

     第七种方法:grid

      在父元素里加:

       display: grid;

      在子元素里加:

       align-self: center;
       justify-self: center;

      代码如下:

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>test</title>
        <style>
            #box {
                width: 250px;
                height: 250px;
                background-color: yellowgreen;
                display: grid;
            }
    
            .inner {
                width: 100px;
                height: 100px;
                background-color: red;
    
                align-self: center;
                justify-self: center;
            }
        </style>
    </head>
    
    <body>
        <div id="box" title="坚韧不拔">
            <div class="inner">浑然天成</div>
        </div>
    </body>
    
    </html>

      效果如下:

      

      如有疑问请加群,讨论854184700

      

     

     

      

      

     

  • 相关阅读:
    数据库课程设计心得【3】存储过程的运用
    看BBC研究大脑的科教片中“放松产生灵感”的笔记
    成功干掉“恶心的U盘自动运行病毒免疫目录”!共享方法,让更多的人干掉这东西!
    分享一大堆最新dot net asp.net c# 电子书下载 , 英文原版的。经典中的经典
    SQL学习之 对GROUP BY 和 HAVING 的理解 学习笔记
    关于Theme中.skin与css需要理清的关系
    最近的学习笔记,记录一些通俗易懂的学习类文章。更像是好资料参与索引。
    关于DNN Module开发学习以来的一点总结
    工具发布!QQ空间阅读与备份工具
    被忽视的大道理
  • 原文地址:https://www.cnblogs.com/yaosusu/p/11703270.html
Copyright © 2011-2022 走看看