Flex item should align left, not center, when it wraps

前端 未结 3 1554
闹比i
闹比i 2020-11-27 08:27

I have a flex-based unordered list of social media icons at the bottom of a mobile menu on my website.

I\'m trying to get rows of three to sit side by side, equal di

相关标签:
3条回答
  • 2020-11-27 08:40

    Remove the margins on the li tag.

    Also don't forget that ul and li have default styles applied by the browser. Consider using a css reset to have consistency across all browsers.

    0 讨论(0)
  • 2020-11-27 09:00

    Not possible with native flexbox...or any other layout methods for that matter. There are workarounds but without those..not really.

    However, if the number of possible extra left-over items is known (in this case 2) you can add hidden items to even things out...see I said it was hacky.

    * {
      -webkit-box-sizing: border-box;
      -moz-box-sizing: border-box;
      box-sizing: border-box;
    }
    .box {
      width: 275px;
      height: 175px;
      background-color: yellow;
    }
    ul {
      width: auto;
      display: flex;
      flex-direction: row;
      justify-content: space-around;
      flex-wrap: wrap;
      padding: 30px 20px 30px 20px;
      list-style: none;
    }
    li {
      width: 30px;
      height: 30px;
      margin: 15px;
      background-color: red;
    }
    .hidden {
      opacity: 0;
      height: 0;
    }
    <div class="box">
    
      <ul>
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
        <li>5</li>
        <li class="hidden"></li>
        <li class="hidden"></li>
      </ul>
    
    </div>
    
    <div class="box">
    
      <ul>
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
        <li class="hidden"></li>
        <li class="hidden"></li>
      </ul>
    
    </div>

    0 讨论(0)
  • 2020-11-27 09:04

    Solution

    Instead of justify-content: space-around use justify-content: space-between.


    Explanation

    Take a look at the flexbox 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.

    There are five values that apply to justify-content. Here are two of them:

    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.

    Emphasis mine. That's the problem you're having.

    Now check out space-between:

    space-between

    Flex items are evenly distributed in the line.

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

    So, to left-align your flex item on wrap, use space-between.

    Then, if necessary, you can add some left and right padding to the container to simulate space-around.


    Of course, the next problem you'll face is when two items wrap, and each item aligns at opposite ends. But that's another question altogether :-)

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