Vertically center two elements within a div

后端 未结 2 1552
我寻月下人不归
我寻月下人不归 2020-11-22 10:05

I am trying to vertically center two

elements.

I followed the tutorial at phrogz.net but still the elements get placed above the div, below th

相关标签:
2条回答
  • 2020-11-22 10:42

    How to Center Elements Vertically, Horizontally or Both

    Here are two ways to center divs within divs.

    One way uses CSS Flexbox and the other way uses CSS table and positioning properties.

    In both cases, the height of the centered divs can be variable, undefined, unknown, whatever. The height of the centered divs doesn't matter.

    Here's the HTML for both:

    <div id="container">   
    
        <div class="box" id="bluebox">
            <p>DIV #1</p>
        </div>
    
        <div class="box" id="redbox">
            <p>DIV #2</p>
        </div>
    
    </div>
    

    CSS Flexbox Method

    #container {
        display: flex;              /* establish flex container */
        flex-direction: column;     /* stack flex items vertically */
        justify-content: center;    /* center items vertically, in this case */
        align-items: center;        /* center items horizontally, in this case */
        height: 300px;
        border: 1px solid black;
    }
    
    .box {
        width: 300px;
        margin: 5px;
        text-align: center;
    }
    

    DEMO

    The two child elements (.box) are aligned vertically with flex-direction: column. For horizontal alignment, switch the flex-direction to row (or simply remove the rule as flex-direction: row is the default setting). The items will remain centered vertically and horizontally (DEMO).


    CSS Table and Positioning Method

    body {
        display: table;
        position: absolute;
        height: 100%;
        width: 100%;
    }
    
    #container {
        display: table-cell;
        vertical-align: middle;
    }
    
    .box {
        width: 300px;
        padding: 5px;
        margin: 7px auto;   
        text-align: center;
    }
    

    DEMO


    Which method to use...

    If you're not sure which method to use, I would recommend flexbox for these reasons:

    1. minimal code; very efficient
    2. as noted above, centering is simple and easy (see another example)
    3. equal height columns are simple and easy
    4. multiple options for aligning flex elements
    5. it's responsive
    6. unlike floats and tables, which offer limited layout capacity because they were never intended for building layouts, flexbox is a modern (CSS3) technique with a broad range of options.

    Browser support

    Flexbox is supported by all major browsers, except IE < 10. Some recent browser versions, such as Safari 8 and IE10, require vendor prefixes. For a quick way to add prefixes use Autoprefixer. More details in this answer.

    0 讨论(0)
  • 2020-11-22 10:44

    Add the following: display:table; to bannerRight

    display:table-cell; and vertical-align:middle; to bannerrightinner

    I have not tried this, please give me feedback if it does not work. ;)

    EDIT: forgot to mention: take 'float' and 'position' properties off

    0 讨论(0)
提交回复
热议问题