Многоточие переполнения текста на двух строках
Я знаю, что вы можете использовать комбинацию правил CSS, чтобы текст заканчивается многоточием (...) когда пришло время переполнения (выйти из родительских границ).
возможно ли (не стесняйтесь просто сказать, нет) достичь того же эффекта, но пусть текст переносится на более чем одну строку?
div {
width: 300px;
height: 42px;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
Как вы можете видеть, текст заканчивается многоточием, когда он становится шире, чем ширина div. Тем не менее, есть еще достаточно места для текста, чтобы оберните на второй линии и продолжайте. Это прерывается white-space: nowrap
, что требуется для работы многоточия.
какие идеи?
P. S.: Не в JS решения, чистом CSS, если это возможно.
10 ответов:
Я не уверен, что вы видели этой, но Крис Койер отличный CSS-Tricks.com опубликовал ссылку на это некоторое время назад, и это чистое решение CSS, которое выполняет именно то, что вы ищете.
(Нажмите, чтобы посмотреть на CodePen)
HTML:
<div class="ellipsis"> <div> <p> Call me Ishmael. Some years ago – never mind how long precisely – having little or no money in my purse, and nothing particular to interest me on shore, I thought I would sail about a little and see the watery part of the world. It is a way I have of driving off the spleen, and regulating the circulation. Whenever I find myself growing grim about the mouth; whenever it is a damp, drizzly November in my soul; whenever I find myself involuntarily pausing before coffin warehouses, and bringing up the rear of every funeral I meet; and especially whenever my hypos get such an upper hand of me, that it requires a strong moral principle to prevent me from deliberately stepping into the street, and methodically knocking people's hats off – then, I account it high time to get to sea as soon as I can. </p> </div> </div>
CSS:
html,body,p { margin: 0; padding: 0; font-family: sans-serif; } .ellipsis { overflow: hidden; height: 200px; line-height: 25px; margin: 20px; border: 5px solid #AAA; } .ellipsis:before { content: ""; float: left; width: 5px; height: 200px; } .ellipsis > *:first-child { float: right; width: 100%; margin-left: -5px; } .ellipsis:after { content: "026"; box-sizing: content-box; -webkit-box-sizing: content-box; -moz-box-sizing: content-box; float: right; position: relative; top: -25px; left: 100%; width: 3em; margin-left: -3em; padding-right: 5px; text-align: right; background-size: 100% 100%;/* 512x1 image,gradient for IE9. Transparent at 0% -> white at 50% -> white at 100%.*/ background-image:url(); background: -webkit-gradient(linear,left top,right top, from(rgba(255,255,255,0)),to(white),color-stop(50%,white)); background: -moz-linear-gradient(to right,rgba(255,255,255,0),white 50%,white); background: -o-linear-gradient(to right,rgba(255,255,255,0),white 50%,white); background: -ms-linear-gradient(to right,rgba(255,255,255,0),white 50%,white); background: linear-gradient(to right,rgba(255,255,255,0),white 50%,white); }
конечно, будучи чистым решением CSS означает, что это также довольно сложный, но он работает чисто и элегантно. Я предположим, что Javascript не может быть и речи, потому что это намного проще достичь (и, возможно, более деградируемо) с помощью Javascript.
в качестве дополнительного бонуса, есть загружаемый zip-файл полного процесса (если вы хотите понять его и все), но и файл Sass mixin, чтобы вы могли легко сложить его в свой процесс.
надеюсь, что это помогает!
простые свойства CSS могут сделать трюк. Ниже приводится трехстрочный многоточие.
display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis;
взгляните на эту чистую версию css:http://codepen.io/martinwolf/pen/qlFdp
display: block; display: -webkit-box; max-width: 400px; height: 109.2px; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; line-height: 1.625;
Css ниже должен сделать трюк.
после второй строки, текст будет содержать ...
line-height: 1em; max-height: 2em; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2;
мое решение повторно использует один из amcdnl, но мой запасной вариант состоит из использования высоты для текстового контейнера:
.my-caption h4 { display: -webkit-box; margin: 0 auto; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis; height: 40px;/* Fallback for non-webkit */ }
text-overflow: ellipsis; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; line-height: 36px; max-height: 18px; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
Я нашел комбинацию как линейных зажимов, так и линейных высот :D
вот простой скрипт для управления точками с помощью jQuery. Он проверяет реальную высоту элемента и создает скрытый исходный узел и усеченный узел. При нажатии происходит переключение между двумя версиями.
одним из больших преимуществ является то, что "многоточие" рядом с последним словом, как и ожидалось.
Если вы используете чистые решения CSS, три точки появляются вдали от последнего слова.
function manageShortMessages() { $('.myLongVerticalText').each(function () { if ($(this)[0].scrollHeight > $(this)[0].clientHeight) $(this).addClass('ellipsis short'); }); $('.myLongVerticalText.ellipsis').each(function () { var original = $(this).clone().addClass('original notruncation').removeClass('short').hide(); $(this).after(original); //debugger; var shortText = ''; shortText = $(this).html().trim().substring(0, 60) + '...'; $(this).html(shortText); }); $('.myLongVerticalText.ellipsis').click(function () { $(this).hide(); if ($(this).hasClass('original')) { $(this).parent().find('.short').show(); } else { $(this).parent().find('.original').show(); } }); } manageShortMessages();
div { border:1px solid red; margin:10px; } div.myLongVerticalText { height:30px; width:450px; } div.myLongVerticalText.ellipsis { cursor:pointer; } div.myLongVerticalText.original { display:inline-block; height:inherit; }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <body> <div class="myLongVerticalText"> Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse sit amet quam hendrerit, sagittis augue vel, placerat erat. Aliquam varius porta posuere. Aliquam erat volutpat. Phasellus ullamcorper malesuada bibendum. Etiam fringilla, massa vitae pulvinar vehicula, augue orci mollis lorem, laoreet viverra massa eros id est. Phasellus suscipit pulvinar consectetur. Proin dignissim egestas erat at feugiat. Aenean eu consectetur erat. Nullam condimentum turpis eu tristique malesuada. Aenean sagittis ex sagittis ullamcorper auctor. Sed varius commodo dui, nec consectetur ante condimentum et. Donec nec blandit mi, vitae blandit elit. Phasellus efficitur ornare est facilisis commodo. Donec convallis nunc sed mauris vehicula, non faucibus neque vehicula. Donec scelerisque luctus dui eu commodo. Integer eu quam sit amet dui tincidunt pharetra eu ac quam. Quisque tempus pellentesque hendrerit. Sed orci quam, posuere eu feugiat at, congue sed felis. In ut lectus gravida, volutpat urna vitae, cursus justo. Nam suscipit est ac accumsan consectetur. Donec rhoncus placerat metus, ut elementum massa facilisis eget. Donec at arcu ac magna viverra tincidunt. </div> <div class="myLongVerticalText"> One Line Lorem ipsum dolor sit amet. </div> </body>
основываясь на ответе, который я видел в stackoveflow, я создал этот LESS mixin (используйте эту ссылку для создания кода CSS):
.max-lines(@lines: 3; @line-height: 1.2) { overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: @lines; line-height: @line-height; max-height: @line-height * @lines; }
использование
.example-1 { .max-lines(); } .example-2 { .max-lines(3); } .example-3 { .max-lines(3, 1.5); }
Это полный хак, но он работает:
div { width: 30%; float: left; margin-right: 2%; height: 94px; overflow: hidden; position: relative; } div:after { display: block; content: '...'; width: 1em; height: 1.5em; background: #fff; position: absolute; bottom: -6px; right: 0; }
у него есть проблемы.... это может отрезать письмо неловко, и это, вероятно, будет иметь некоторые странные результаты на отзывчивом сайте.
Не уверен, что ваша цель, но вы хотите, чтобы текст появился на второй линии?
вот ваш jsFiddle:http://jsfiddle.net/8kvWX/4/ просто удалил следующее:
white-space:nowrap;
Я не уверен, если это то, что вы ищете или нет.
С уважением,
Mee