Método de centralização vertical da caixa CSS

1. O método de centralizar a caixa verticalmente
  1. Deixe as bordas superior e inferior da caixa se sobreporem à linha central horizontal da caixa pai e, em seguida, deixe a caixa filha recuar metade de sua distância.

  <div class="father">
        <div class="son"></div>
    </div>
  /* 通过 transform 属性来移动*/
    .father {
    
    
        width: 500px;
        height: 500px;
        background-color: skyblue;
        border: 1px solid #000;
        margin: 0 auto;
    }

    .son {
    
    
        width: 200px;
        height: 200px;
        background-color: pink;
        border: 1px solid #000;
        margin-top: 50%; // 向下移动父盒子的一半
        transform: translateY(-50%); // 向上移动自身盒子的一半
    }  
     /* 通过 定位来移动*/
    .father {
    
    
        width: 500px;
        height: 500px;
        background-color: skyblue;
        border: 1px solid #000;
        margin: 0 auto;
        position: relative;
    }

    .son {
    
    
        width: 200px;
        height: 200px;
        background-color: pink;
        border: 1px solid #000;
        position: absolute;
        top: 50%; // 先向下移动父盒子的一半
        margin-top: -100px; // 再向上移动自身盒子的一半

    }

Insira a descrição da imagem aqui
3. Sabendo a altura da caixa pai, você pode usar a margem para calcular as margens superior e inferior da caixa para centralizar a caixa.

.father {
    
    
            width: 500px;
            height: 500px;
            background-color: skyblue;
            border: 1px solid #000;
            margin: 50px auto;

        }
        .son {
    
    
            width: 200px;
            height: 200px;
            background-color: pink;
            border: 1px solid #000;
            margin-top: 149px;         // 根据父盒子的高度指定 margin-top 即可
        }

Em segundo lugar, o método de centralizar horizontalmente a caixa
  1. Use margin: 0 auto;

.father {
    
    
            width: 500px;
            height: 500px;
            background-color: skyblue;
            border: 1px solid #000;
            margin: 50px auto;

        }
        .son {
    
    
            width: 200px;
            height: 200px;
            background-color: pink;
            border: 1px solid #000;
            margin: 0 auto;           // 让盒子左右自动适应,想当于 left:auto; right:auto
        }

2. Alcance a centralização calculando as margens esquerda e direita da margem

.father {
    
    
            width: 500px;
            height: 500px;
            background-color: skyblue;
            border: 1px solid #000;
            margin: 50px auto;

        }
        .son {
    
    
            width: 200px;
            height: 200px;
            background-color: pink;
            border: 1px solid #000;
            margin-left: 149px;          // 父盒子的定宽的,指定 margin-left 即可
        }

3. Primeiro faça as bordas esquerda e direita da caixa perpendiculares à linha central vertical da caixa pai e, em seguida, mova a caixa filha para trás pela metade de sua própria largura

/* 通过 transform 实现*/
    .father {
    
    
            width: 500px;
            height: 500px;
            background-color: skyblue;
            border: 1px solid #000;
            margin: 50px auto;

        }
        .son {
    
    
            width: 200px;
            height: 200px;
            background-color: pink;
            border: 1px solid #000;
            margin-left: 50%;                // 先移动父盒子的一半
            transform: translateX(-50%);     // 再移动自身盒子一半

        }
    /*通过 定位实现*/
    .father {
    
    
            width: 500px;
            height: 500px;
            background-color: skyblue;
            border: 1px solid #000;
            margin: 50px auto;
            position: relative;

        }
        .son {
    
    
            width: 200px;
            height: 200px;
            background-color: pink;
            border: 1px solid #000;
            position: absolute;
            left: 50%;                       // 向右移动父盒子一半
            margin-left: -100px;             // 向左移动自身盒子一半
            /* transform: translateX(-50%); */    //向左移动自身盒子一半 38 }

4. Transforme a caixa em um bloco embutido e, em seguida, use o atributo de alinhamento de texto para centralizar a caixa horizontalmente

.father {
    
    
            width: 500px;
            height: 500px;
            background-color: skyblue;
            border: 1px solid #000;
            margin: 50px auto;
            text-align: center;               // 让父盒子设置水平居中

        }
        .son {
    
    
            width: 200px;
            height: 200px;
            background-color: pink;
            border: 1px solid #000;
            display: inline-block;            // 让子盒子显示为行内块模式
        }

Acho que você gosta

Origin blog.csdn.net/weixin_44433499/article/details/107412988
Recomendado
Clasificación