zoukankan      html  css  js  c++  java
  • 垂直水平居中的几种方法

    一、固定宽高:
    1、margin

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

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

    .box-container{
    position: relative;
    300px;
    height: 300px;
    }
    .box-container .box {
    200px;
    height: 100px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-top: -50px; /* 高度的一半 */
    margin-left: -100px; /* 宽度的一半 */
    }
    设置父元素的position为相对定位,子元素绝对定位,并在 top 和 left 方向上移动父元素50%的距离。

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

    3、定位 + margin

    .box-container{
    position: relative;
    }
    .box {
    100px;
    height: 100px;
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    }
    同样是使用绝对定位,但四个方向的偏移量全都为0,之后设置 margin:auto 分配剩余空间,令元素的均匀拖拽至父元素的中心位置。

    二、未知宽高
    1、transform 方案: 存在兼容问题:

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

    注意:transform存在浏览器兼容问题,如下表。

    2、flexbox 方案: 存在兼容问题

    .box-container {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: center;
    align-items: center;
    }
    设置父元素为 flex 弹性盒模型,并在主轴和副轴上设置居中,关于弹性盒模型的详情请点击这里。

    作为新增属性,flex同样存在兼容问题,如下表:

    3、display: table-cell 无兼容性问题

    .box {
    position: relative;
    300px;
    height: 300px;
    border: 1px solid red;
    display: table-cell;
    text-align: center;
    vertical-align: middle;
    }
    只需要设置父元素即可,text-align: center; 并在竖直方向上令内容居中(middle),早期属性,不存在兼容问题。
    ———————————————

  • 相关阅读:
    作业三3
    作业三2(改过)
    第一章
    实验2
    第三章
    例2-11
    例2-10
    例2-8
    例2-9
    例2-7
  • 原文地址:https://www.cnblogs.com/dillonmei/p/12569102.html
Copyright © 2011-2022 走看看