搜尋

首頁  >  問答  >  主體

css - 在绝对定位的情况下怎么让div居中呢?

<html>
<head>
    <title></title>
    <style type="text/css">
    #p1{width: 300px;height: 200px;background-color: blue;position: absolute;}
    #p2{width: 50px;height: 50px;background-color: red;margin: 0 auto;position: absolute;bottom:20px;}
    </style>
</head>
<body>
<p id="p1">
    <p id="p2"></p>
</p>
</body>
</html>
怪我咯怪我咯2843 天前958

全部回覆(5)我來回復

  • 黄舟

    黄舟2017-04-17 13:45:56

    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%,-50%)

    這種方法比較適合自身寬高和容器寬高不明確的情況

    補充,自己總結的幾種居中方法:

    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <style>
        .father {
            width: 100px;
            height: 100px;
            border: 1px solid red;
            margin: 20px;
        }
    
        .child {
            width: 50px;
            height: 50px;
            border: 1px solid red;
            margin-left: auto;
            margin-right: auto;
        }
    /*
        方法一:
        对子元素使用margin居中 
        使用场景:
        + 父元素高度固定;
        + 子元素高度固定
        简单粗暴,适用于子元素和父元素的宽高都固定的情况。
    */
    
        .method1 .child {
            margin-top: 25px;
        }
        /*
        方法二:
        适用于子元素高度和宽度固定,父元素高度不固定
     */
    
        .method2 {
            position: relative;
        }
    
        .method2 .child {
            position: absolute;
            top: 50%;
            left: 50%;
            margin-top: -25px;
            margin-left: -25px;
        }
        /*
       方法三:
       子元素和父元素高度不定
       利用transform来调整位置
         */
    
        .method3 {
            position: relative;
        }
    
        .method3 .child {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
        }
        /*
        方法四:
        使用flex布局,利用flex-direction属性*/
    
        .method4 {
            display: flex;
            justify-content: center;
            flex-direction: column;
        }
        /*
        方法五:
        使用flex布局,利用align-items属性*/
    
        .method5 {
            display: flex;
            display: -webkit-flex;
            align-items: center;
        }
        /*
        方法六:
        使用table-cell布局
         */
    
        .method6 {
            display: table-cell;
            vertical-align: middle;
            text-align: center;
        }
    
        .method6 .child {
            vertical-align: middle;
        }
        </style>
    </head>
    
    <body>
        <p class="father method1">
            <p class="child"></p>
        </p>
        <p class="father method2">
            <p class="child"></p>
        </p>
        <p class="father method3">
            <p class="child"></p>
        </p>
        <p class="father method4">
            <p class="child"></p>
        </p>
        <p class="father method5">
            <p class="child"></p>
        </p>
          <p class="father method6">
            <p class="child"></p>
        </p>
    </body>
    
    </html>

    最終效果

    回覆
    0
  • 迷茫

    迷茫2017-04-17 13:45:56

    設定left值吧

    回覆
    0
  • PHP中文网

    PHP中文网2017-04-17 13:45:56

    雷雷

    回覆
    0
  • 阿神

    阿神2017-04-17 13:45:56

    雷雷

    回覆
    0
  • ringa_lee

    ringa_lee2017-04-17 13:45:56

    不會用搜尋?在社區搜一搜就有答案,何必重複這麼多問題。

    @_qunshan_

    @_qunshan_的答案

    回覆
    0
  • 取消回覆