【问题标题】:Align two images in the middle with text on the opposite sides将中间的两个图像与相对两侧的文本对齐
【发布时间】:2020-05-02 13:31:16
【问题描述】:

我正在尝试重新创建下面的图像,其中两个图像在中间,文本在相对两侧。

我尝试了一些不同的东西,flexbox,没有 flexbox,浮动元素,但都无法让它们工作。

example of the desired outcome

这是我目前正在使用的:

ul {
   list-style-type: none;
}

.inspiration-list-container {
    display: flex;
    flex-wrap: wrap;
    margin: 0 -16px;
}

.inspiration-list-container li {
    width: 50%;
    padding: 0 8px 16px;
}

.inspiration-list-container li a {
    display: flex;
    color: inherit;
    line-height: inherit;
    letter-spacing: inherit;
}

.inspiration-list-container li:nth-child(odd) .inspiration-description {
    margin-right: 8px;
    text-align: right;
    align-items: flex-end;
}

.inspiration-list-container li .inspiration-description {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: calc(50% - 8px);
}

.inspiration-list-container li .brand-logo {
    object-fit: contain;
    max-width: 64px;
}

.inspiration-list-container li .inspiration-description .p-legal {
    font-family: Avenir Bold,Helvetica Neue,Helvetica,sans-serif;
    font-size: .875rem;
    line-height: 32px;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.inspiration-list-container li .p-copy-2 {
    line-height: 25px;
}

.inspiration-list-container li:nth-child(odd) .inspiration-image-container {
    margin-left: 8px;
}

.inspiration-list-container li .inspiration-image-container {
    width: calc(50% - 8px);
    position: relative;
}

.inspiration-list-container li .inspiration-image.placeholder {
    visibility: hidden;
}

.inspiration-list-container li .inspiration-image {
    width: 100%;
    object-fit: contain;
}

.inspiration-list-container li .inspiration-image.actual {
    position: absolute;
    left: 0;
    top: 0;
}

.inspiration-list-container li .inspiration-image {
    width: 100%;
    object-fit: contain;
}
<ul class="inspiration-list-container">
  <li>
    <a href="#">
      <div class="inspiration-description">
        <p>Success Story</p>
        <p>placeholder</p>
      </div>
      <div class="inspiration-image-container">
        <img src="https://images.ctfassets.net/inb32lme5009/4nojcxZUzehUfJ5JCGJpTQ/ab6b80302fa1c48d50c51b31d354517e/sephora_thumbnail_375x667.png">
      </div>
    </a>
  </li>
  <li>
    <a href="#">
      <div class="inspiration-description">
        <p>Success Story</p>
        <p>placeholder</p>
      </div>
      <div class="inspiration-image-container">
        <img src="https://images.ctfassets.net/inb32lme5009/4nojcxZUzehUfJ5JCGJpTQ/ab6b80302fa1c48d50c51b31d354517e/sephora_thumbnail_375x667.png">
      </div>
    </a>
  </li>
</ul>

我目前正在使用 Bootstrap 和 Flexbox 来尝试使其正常工作,但我完全被卡住了。

感谢您的宝贵时间。

【问题讨论】:

    标签: html css bootstrap-4 flexbox


    【解决方案1】:

    试试这个:

    html:

    <div class="flex-container">
      <div><div class="inspiration-description">
            <p>Success Story</p>
            <p>placeholder</p>
          </div>
      </div>
      <div><img src="https://images.ctfassets.net/inb32lme5009/4nojcxZUzehUfJ5JCGJpTQ/ab6b80302fa1c48d50c51b31d354517e/sephora_thumbnail_375x667.png"></div>
      <div><img src="https://images.ctfassets.net/inb32lme5009/4nojcxZUzehUfJ5JCGJpTQ/ab6b80302fa1c48d50c51b31d354517e/sephora_thumbnail_375x667.png"></div>  
      <div>
         <div class="inspiration-description">
            <p>Success Story</p>
            <p>placeholder</p>
          </div>
      </div> 
    </div>
    

    css:

    .flex-container {
      display: flex;
      flex-wrap: nowrap; 
      align-items:center;
    }
    
    .flex-container > div { 
      width: 400;
      margin: 10px;
      text-align: center;
      line-height: 75px;
      font-size: 30px;
    }
    .flex-container > div > img{
      vertical-align:middle
    }
    
    .inspiration-description p {
        font-family: Avenir Bold,Helvetica Neue,Helvetica,sans-serif;
        font-size: .875rem;
        display: inline-block;
      vertical-align: middle;
      line-height: normal;
        letter-spacing: 1px;
        text-transform: uppercase;
        line-height: 1.5; 
       }
    
    
    

    小提琴:https://jsfiddle.net/aviboy2006/6rqLax8v/19/

    【讨论】:

    • 谢谢,好多了。如何垂直对齐图像旁边的文本?
    • 你的意思是你需要图像的中心和图像旁边?
    • 文本在图像旁边垂直居中。就像截图一样。 i.stack.imgur.com/IMmiB.png
    • @bigRadBrad 添加了新更改
    • 谢谢你,你对让这个移动响应有什么建议吗?