我有这个简单的HTML设置:

<a>
  <span class='amount'>XX €</span>
  <span class='text'>
    <span>COIN</span>
    <span>foo</span>
  </span>
</a>


小提琴:http://jsfiddle.net/k5fas9yy/2/

我想要的是浮动元素在flexbox的右边。在Chrome,Edge,IE11中正常运行。但是对于Firefox,似乎a占用了flex容器的宽度,这将flexbox放在了浮动元素下方。如何使它成长为正确地适合所有事物?

最佳答案

代替display:flex,使用display:inline-flex



* {
  box-sizing: border-box;
}
a {
  color: white;
  background-color: lightblue;
  display: inline-block;
  height: 45px;
  margin: 0;
  padding: 7.5px 15px;
  border: none;
  font-size: 10pt;
}
.amount {
  float: right;
  margin-left: 2rem;
  font-size: 1.6rem;
  margin-top: 10px;
}
.text {
  padding-top: 5px;
  padding-left: 0.3rem;
  display: inline-flex;
  flex-flow: column nowrap;
  align-items: flex-start;
  background-color: pink;
}

<a>
  <span class='amount'>XX €</span>
  <span class='text'>
        <span>COIN</span>
  <span>foo</span>
  </span>
</a>





在FF 41.0.2中测试

10-05 21:00
查看更多