Using 'order' property to position flex item between siblings

后端 未结 1 1779
粉色の甜心
粉色の甜心 2021-01-13 19:14

I have a flex-box with one to three flex-items.

The proper layout should look like

i
1条回答
  •  暖寄归人
    2021-01-13 19:52

    When there are three elements in the container:

    • div
    • h2
    • div

    AND

    • the order of these elements varies in the source...

    AND

    • you want the h2 to always be in the middle...

    THEN, you can do something like this:

    .container > div:first-of-type { order: 1; }
    .container > h2 { order: 2; }
    .container > div:last-of-type { order: 3; }
    

    This translates to:

    Regardless of the order of elements in the source,

    • The first div will appear first in the visual order
    • The h2 will appear second in the visual order
    • The second div will appear last in the visual order

    .container {
      display: flex;
    }
    .container > * {
      flex: 1;
      border: 1px dashed red;
    }
    h2 { 
      text-align: center;
      margin: 0;
    }
    
    .container > div:first-of-type { order: 1; }
    .container > h2 { order: 2; }
    .container > div:last-of-type { order: 3; }
    
    p { text-align: center;}
    p > span { background-color: aqua; padding: 5px; }

    I'm an h2

    I'm span 1 I'm span 2 I'm span 3
    I'm span 1 I'm span 2 I'm span 3

    I'm an h2

    I'm span 4 I'm span 5 I'm span 6
    I'm span 1 I'm span 2

    I'm an h2

    I'm span 3
    I'm a span I'm a span

    I'm an h2

    I'm a span I'm a span

    I'm an h2

    I'm an h2

    I'm a span I'm a span
    I'm a span I'm a span

    TRUE CENTER


    For situations where there is one element in the container, add justify-content: space-around.

    Because each item already has flex: 1 applied, space-around will have no effect when there are two or more items in the container.

    However, when there is only one item, space-around resolves to center.

    From the spec:

    8.2. Axis Alignment: the justify-content property

    The justify-content property aligns flex items along the main axis of the current line of the flex container.

    space-around

    Flex items are evenly distributed in the line, with half-size spaces on either end.

    If the leftover free-space is negative or there is only a single flex item on the line, this value is identical to center.

    .container {
      display: flex;
      justify-content: space-around; /* NEW */
    }
    .container > * {
      flex: 1;
      border: 1px dashed red;
    }
    h2 { 
      text-align: center;
      margin: 0;
    }
    
    .container > div:first-of-type { order: 1; }
    .container > h2 { order: 2; }
    .container > div:last-of-type { order: 3; }
    
    p { text-align: center;}
    p > span { background-color: aqua; padding: 5px; }

    I'm an h2

    I'm span 1 I'm span 2 I'm span 3
    I'm span 1 I'm span 2 I'm span 3

    I'm an h2

    I'm span 4 I'm span 5 I'm span 6
    I'm span 1 I'm span 2

    I'm an h2

    I'm span 3
    I'm a span I'm a span

    I'm an h2

    I'm a span I'm a span

    I'm an h2

    I'm an h2

    I'm a span I'm a span
    I'm a span I'm a span

    I'm an h2

    TRUE CENTER

    You are now covered for ONE and THREE flex items.

    For TWO items, it gets a bit trickier.

    Since you always want the h2 centered, I would suggest having two divs in the container at all times, even if they're empty. Then flex: 1 will give all three items equal width.

    .container {
      display: flex;
      justify-content: space-around;
    }
    .container > * {
      flex: 1;
      border: 1px dashed red;
    }
    h2 { 
      text-align: center;
      margin: 0;
    }
    
    .container > div:first-of-type { order: 1; }
    .container > h2 { order: 2; }
    .container > div:last-of-type { order: 3; }
    
    p { text-align: center;}
    p > span { background-color: aqua; padding: 5px; }

    I'm an h2

    I'm span 1 I'm span 2 I'm span 3
    I'm span 1 I'm span 2 I'm span 3

    I'm an h2

    I'm span 4 I'm span 5 I'm span 6
    I'm span 1 I'm span 2

    I'm an h2

    I'm span 3
    I'm a span I'm a span

    I'm an h2

    I'm a span I'm a span

    I'm an h2

    I'm an h2

    I'm a span I'm a span
    I'm a span I'm a span

    TRUE CENTER

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