7

我有一个标题:

<h2><a href="#">Lorem ipsum dolor dumbledore at hogwarts</a></h2>

如果文本超过以下高度,我将尝试截断多行文本h2

h2 {
  width: 200px;
  height: 52px;
  overflow: hidden;
  text-overflow: ellipsis;
}

我所期待的:

Lorem ipsum dolor 
dumbledore at...

结果是什么

Lorem ipsum dolor
dumbledore at

为什么省略号不显示?

当我添加white-space: nowrap;省略号时,显示的文本h2现在是单行而不是占据h2.

Lorem ipsum dolor...
4

2 回答 2

3

您可以使用一些现代 css 技巧来做到这一点,请参阅jsfidle 示例

body{padding: 4em;}
h3{border:2px solid red;padding:.5em;}

h3 {
display: block; /* Fallback for non-webkit */
display: -webkit-box;
max-width: 400px;
height: calc(26px*1.4*4); /* Fallback for non-webkit */
margin: 0 auto;
font-size: 26px;
line-height: 1.4;
-webkit-line-clamp:4;
-webkit-box-orient: vertical;
overflow: hidden;
text-overflow: ellipsis;
}

<h3>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis, sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu. </h3>
于 2013-02-21T10:12:29.717 回答
2

Quirksmode.org(必读!)建议您还需要white-space: nowrap;.

于 2012-10-01T07:53:43.927 回答