当前位置: 首页 > 面试题库 >

flexbox容器中的省略号

明安阳
2023-03-14
问题内容

自从Firefox Nightly(35.0a1)的最新(?)版本以来,我一直在使用text-overflow: ellipsis的flexbox容器内部遇到问题flex-direction: row,每个列的宽度为50%。

演示:

.container {

  width: 300px;

  background: red;

}



.row {

  display: flex;

  flex-direction: row;

  flex-wrap: wrap;

}



.column {

  flex-basis: 50%;

}



.column p {

  background: gold;



  /* Will not work in Firefox Nightly 35.0a1 */

  text-overflow: ellipsis;

  overflow: hidden;

  white-space: nowrap;

}


<div class="container">

  <div class="row">

    <div class="column">

      <p>Captain's Log, Stardate 9529.1: This is the final cruise of the starship Enterprise under my command. This ship and her history will shortly become the care of another crew. To them and their posterity will we commit our future. They will continue the voyages we have begun and journey to all the undiscovered countries boldly going where no man, where no one has gone before.</p>

    </div>

    <div class="column">

      <p>Captain's Log, Stardate 9529.1: This is the final cruise of the starship Enterprise under my command. This ship and her history will shortly become the care of another crew. To them and their posterity will we commit our future. They will continue the voyages we have begun and journey to all the undiscovered countries boldly going where no man, where no one has gone before.</p>

    </div>

  </div>

</div>

在“每晚”中,文本将泄漏到其容器外部,并且不会...在末尾附加。在Chrome和Firefox稳定版中,它可以按预期工作。


问题答案:

最终可以追溯到Firefox Nightly中的最新更改。长话短说,选择器min-width:0上的设置.column将使其按预期工作。

在这里可以找到更全面的答案。注意:

“基本上:弹性项目将拒绝收缩到其最小固有宽度以下,除非您在其上明确指定“最小宽度”或“宽度”或“最大宽度”。

工作解决方案:

.container {

  width: 300px;

  background: red;

}



.row {

  display: flex;

  flex-direction: row;

  flex-wrap: wrap;

}



.column {

  /* This will make it work in Firefox >= 35.0a1 */

  min-width: 0;

  flex-basis: 50%;

}



.column p {

  background: gold;

  text-overflow: ellipsis;

  overflow: hidden;

  white-space: nowrap;

}


<div class="container">

  <div class="row">

    <div class="column">

      <p>Captain's Log, Stardate 9529.1: This is the final cruise of the starship Enterprise under my command. This ship and her history will shortly become the care of another crew. To them and their posterity will we commit our future. They will continue the voyages we have begun and journey to all the undiscovered countries boldly going where no man, where no one has gone before.</p>

    </div>

    <div class="column">

      <p>Captain's Log, Stardate 9529.1: This is the final cruise of the starship Enterprise under my command. This ship and her history will shortly become the care of another crew. To them and their posterity will we commit our future. They will continue the voyages we have begun and journey to all the undiscovered countries boldly going where no man, where no one has gone before.</p>

    </div>

  </div>

</div>


 类似资料:
  • 自最近(?)Firefox Nightly(35.0a1)的发行版我遇到了一个问题,位于flexbox容器中,该容器具有,每列宽度为50%。 演示: 在夜间,文本将泄漏到其容器外,并且不会附加

  • 我一直在使用空格:不换行,文本溢出:省略号和溢出:隐藏的CSS属性为多行文本创建省略号截断。但是,这在使用弹性框时不起作用。 使用flex时,text-overflow:省略号似乎总是将flex项的高度截断为一行。 对于多行文本,是否可以使用flex和css省略号截断的组合? 我可以让它在单行截断的情况下工作。手动设置高度与flex空格:nowrapp不起作用。

  • 我正在尝试实现以下布局:一个网格有几个固定宽度的列,其中一列包含未知宽度的内容,它将由多个元素组成,不会换行,并且必须用省略号截断。 一个更具体的例子: 以下是我使用flexbox尝试但未成功的内容: 同样的例子在jsbin上 我还尝试使用内联网格而不是flexbox,这也没有任何帮助(jsbin上的示例)。 有没有办法让这一切顺利进行? 免责声明:我意识到这个问题的变体已经被问及堆栈溢出;但所有

  • 我试图把省略号文本溢出: 家长: 儿童: 而且,是,但没有任何省略号。

  • 我正在尝试用flex创建一个布局(将是一个音乐播放器)。 我有3个按钮(上一个、播放和下一个,用红色方块表示),我总是希望它们在同一条线上。 然后,我想在按钮右侧显示一些歌曲信息(当前时间、歌曲标题和总时间)。 我几乎总是希望总时间在最右边,歌曲标题填满剩余的宽度(使用),但随着窗口变小,用省略号截断。 有人知道如何调整它以使其正常工作吗? https://jsfiddle.net/13ohs7j

  • 问题 阻止类似按钮的内容会导致我的flex项目展开并溢出flexbox容器。 预期行为 在本例中,按钮应与按钮文本并排,并用省略号隐藏。flex项的宽度应基于兄弟项而非内容,并在容器更改宽度和添加或删除flex项时保持在容器内的响应性。另一个警告是,对于我的特定场景,我不能在flex项或buttons父div上使用overflow:hidden。 这是小提琴手。 例Html 示例CSS 编辑:现在