zoukankan      html  css  js  c++  java
  • 元素水平垂直居中

    一、定宽定高:

    1、margin

    根据已知的宽高写死,不推荐

    2、绝对定位 + margin-top + margin-left

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        <style>
            .parents{
                background:rgb(70, 68, 68);
                width:400px;
                height:400px;
                position:relative;
    
            }
            .child{
                background:rgb(170, 79, 79);
                width:200px;
                height:100px;
                position:absolute;
                left:50%;
                top:50%;
                margin-top:-50px;
                margin-left:-100px;
    
            }
        </style>
        <div class="parents">
            <div class="child">
                <ul>
                    <li>我要垂直水平居中</li>
                    <li>我用绝对定位+margin</li>
                    <li>我是定宽定高元素</li>
                </ul>
            </div>
        </div>
        
    </body>
    </html>

    设置父元素的position为相对定位,子元素绝对定位,并在 top 和 left 方向上移动父元素50%的距离。

    但这个时候,是子元素的上边框和左边框距离父元素200px,整体向右下角偏了一些,所以还需要再用 margin 调整至中心位置,数值分别是高度和宽度的一半。

    3、绝对定位 + (margin:auto)

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        <style>
            .parents{
                background:rgb(70, 68, 68);
                width:300px;
                height:300px;
                position:relative;
    
            }
            .child{
                background:rgb(170, 79, 79);
                width:200px;
                height:100px;
                position:absolute;
                left:0;
                top:0;
                bottom:0;
                right:0;
                margin:auto;
    
            }
        </style>
        <div class="parents">
            <div class="child">
                <ul>
                    <li>我要垂直水平居中</li>
                    <li>我用绝对定位+marginauto</li>
                    <li>我是定宽定高元素</li>
                </ul>
            </div>
        </div>
        
    </body>
    </html>

    同样是使用绝对定位,但四个方向的偏移量全都为0,之后设置 margin:auto 分配剩余空间,令元素的均匀拖拽至父元素的中心位置。

    二、未知宽高

    1、transform 方案: 存在兼容问题:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        <style>
            .parents{
                background:rgb(70, 68, 68);
                width:300px;
                height:300px;
                position:relative;
                
    
            }
            .child{
                background:rgb(170, 79, 79);
                position:absolute;
                left:50%;
                top:50%;
                transform:translate(-50%,-50%);
    
            }
        </style>
        <div class="parents">
            <div class="child">
                <ul>
                    <li>我要垂直水平居中</li>
                    <li>我用绝对定位+transform</li>
                    <li>我类似于绝对定位+margintop</li>
                    <li>我是定宽定高元素</li>
                </ul>
            </div>
        </div>
        
    </body>
    </html>

    在子元素上设置,transform: translate(-50%, -50%);  用于平面的2D转换,后面的百分比以自身的宽高为参考,定位后将元素的左上角置于父级中央,之后再用 transform 进行偏移,相当于上面设置的 margin-top 和 margin-left。

    2、flex: 兼容问题

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        <style>
            .parents{
                background:rgb(70, 68, 68);
                width:300px;
                height:300px;
                display:flex;
                align-items: center;
                justify-content: center;
                
    
            }
            .child{
                background:rgb(170, 79, 79);
    
            }
        </style>
        <div class="parents">
            <div class="child">
                <ul>
                    <li>我要垂直水平居中</li>
                    <li>我用flex</li>
                    <li>我是不定宽不定高元素</li>
                </ul>
            </div>
        </div>
        
    </body>
    </html>

     设置父元素为 flex 弹性盒模型。

    3.父元素设置table-cell

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    <body>
        <style>
            *{
                margin:0;
                padding:0;
            }
            .grandPa{
                display:table;
                width:300px;
                height:300px;
            }
            .parents{
                background:rgb(70, 68, 68);
                display: table-cell;    
                text-align: center;    
                vertical-align: middle;
                
    
            }
            .child{
                background:rgb(170, 79, 79);           
            }
            li{
                list-style:none;
            }
        </style>
        <div class='grandPa'>
        <div class="parents">
            <div class="child">
                <ul>
                    <li>我要垂直水平居中</li>
                    <li>我用table-cell</li>
                    <li>我是不定宽不定高元素</li>
                </ul>
                <!-- <p>我要垂直水平居中</p>
                <p>我用table-cell</p>
                <p>我是不定宽不定高元素</p> -->
            </div>
        </div>
    </div>
        
    </body>
    </html>

    只需要设置父元素即可,text-align: center; 并在竖直方向上vertical-align:middle;,早期属性,不存在兼容问题。

  • 相关阅读:
    http协议概述
    博客写起来一周年了~
    angular与vue的应用对比
    一些前端的小问题
    详解vue的数据binding原理
    闲的没事水一贴!
    关于angular1与angular2的应用区别
    angularjs优化方略
    rxjs学习笔记
    HTML5移动开发学习笔记
  • 原文地址:https://www.cnblogs.com/sunmarvell/p/14482610.html
Copyright © 2011-2022 走看看