css троеточие в конце многострочного текста
На чтение 8 мин. Просмотров 1 Опубликовано
Допустим у нас есть текст произвольной длины, который должен выводиться внутри блока фиксированной высоты и ширины. Мы хотим, чтобы отображался такой фрагмент текста, который полностью помещается в заданный блок, и многоточие, если текст помещается не полностью. Это довольно распространенная задача, пример подобных блоков показан на рисунке ниже.
В то же время эта задача не является такой тривиальной, как кажется. Давайте рассмотрим возможные варианты ее решения.
Решение на CSS для однострочного текста
Для однострочного текста есть красивое и простое решение на CSS. В этом случае можно использовать свойство text-overflow: ellipsis . При этом контейнер должен иметь свойство overflow равное hidden или clip. Пример:
Решения на CSS для многострочного текста
Один из способов обрезки многострочного текста на CSS использует псевдо-элементы :before и :after.
Другое решение на CSS использует свойство column-w > . Оно задает ширину колонки для многостраничного текста. Вы уже, наверное, догадались, как мы будем его использовать? Правильно, мы зададим ширину колонки, равную ширине блока, а текст, который не помещается в блок, будет во второй, скрытой колонке:
Многоточие при таком способе не добавится, но текст не будет резаться посередине строки.
Интересное решение для многострочного текста на CSS есть для браузеров Webkit. Для этого нужно использовать сразу несколько специфичных свойств с префиксом -webkit:
Свойство -webkit-line-clamp ограничивает количество строк, выводимых в блоке. Работает красиво и элегантно, но из-за своей специфичности в реальном проекте, конечно, такой прием не может использоваться.
Решения на JavaScript
В решении на JavaScript используется еще один невидимый блок, в который мы помещаем нужный текст, потом удаляем по одному символу, пока высота этого блока не станет меньше либо равной высоте нужного блока. И в конце текст помещаем обратно в исходный блок.
Этот же способ можно оформить в виде простенького плагина для jQuery:
Теперь вызов функции обрезки текста сведется к вызову метода truncateText:
Что касается решений на JavaScript, нужно помнить, что операции с DOM’ом: вставка элемента, удаление, изменение его содержимого — являются очень тяжелыми. Поэтому с такими хаками нельзя усердствовать.
Заключение
Мы привели несколько решений для обрезания произвольного текста как на CSS, так и на JavaScript. Если поддержка браузеров позволяет, лучше выбрать решение на CSS — оно будет быстрее, стабильнее, меньше. Если нет — можно использовать JavaScript, но важно помнить о производительности и применять функцию обрезки текста только действительно в нужных местах.
Нашли опечатку? Orphus: Ctrl+Enter
© getinstance.info Все права защищены. 2014–2018
Все права на материалы, публикуемые на данном сайте, принадлежат редакции сайта, за исключением случаев перепечатки чужих материалов, и охраняются в соответствии с законодательством РФ.
Несмотря на то, что мониторы больших диагоналей становятся всё доступнее, а их разрешение постоянно растёт, иногда возникает задача в ограниченном пространстве уместить много текста. Например, это может понадобиться для мобильной версии сайта или для интерфейса, в котором важно число строк. В подобных случаях имеет смысл обрезать длинные строки текста, оставив только начало предложения. Так мы приведём интерфейс к компактному виду и сократим объём выводимой информации. Само обрезание строк можно делать на стороне сервера с помощью того же PHP, но через CSS это проще, к тому же всегда можно показать текст целиком, например, при наведении на него курсора мыши. Далее рассмотрим методы, как текст порезать воображаемыми ножницами.
На деле всё сводится к использованию свойства overflow со значением hidden . Различия лишь кроются в разном отображении нашего текста.
Используем overflow
Чтобы свойство overflow показало себя с текстом во всей красе, надо отменить перенос текста с помощью white-space со значением nowrap . Если это не сделать, то нужного нам эффекта не будет, в тексте добавятся переносы и он будет отображаться весь целиком. В примере 1 показано, как обрезать длинный текст указанным набором стилевых свойств.
Пример 1. overflow для текста
HTML5 CSS3 IE Cr Op Sa Fx
Результат данного примера показан на рис. 1.
Рис. 1. Вид текста после применения свойства overflow
Как видно из рисунка, недостаток в целом один — не очевидно что текст имеет продолжение, так что надо дать об этом понять пользователю. Для этого обычно применяется градиент или многоточие.
Добавляем градиент к тексту
Чтобы стало понятнее, что текст справа не заканчивается, поверх него можно наложить градиент от прозрачного цвета к цвету фона (рис. 2). При этом будет создаваться эффект постепенного растворения текста.
Рис. 2. Текст с градиентом
В примере 2 показано создание этого эффекта. Стиль самого элемента практически останется прежним, сам же градиент будем добавлять с помощью псевдоэлемента ::after и CSS3. Для этого вставляем пустой псевдоэлемент через свойство content и к нему применяем градиент с разными префиксами для основных браузеров (пример 2). Ширину градиента легко изменять через width , также можно регулировать степень прозрачности, заменив значение 0.2 на своё.
Пример 2. Градиент поверх текста
HTML5 CSS3 IE 8 IE 9+ Cr Op Sa Fx
Данный метод не работает в браузере Internet Explorer до версии 8.0 включительно, потому что в нём нет поддержки градиентов. Но можно отказаться от CSS3 и сделать градиент по старинке, через картинку в формате PNG-24.
Этот метод сочетается только с однотонным фоном и в случае фоновой картинки градиент поверх текста будет бросаться в глаза.
Многоточие в конце текста
Вместо градиента в конце обрезанного текста также можно использовать многоточие. Причём оно будет добавляться автоматически с помощью свойства text-overflow . Его понимают все браузеры, включая старые версии IE, и единственным недостатком этого свойства является пока его неясный статус. В CSS3 вроде это свойство входит, но код с ним не проходит валидацию.
В примере 3 показано применение свойства text-overflow со значением ellipsis , которое добавляет многоточие. При наведении курсора мыши на текст, он отображается целиком и подсвечивается фоновым цветом.
Пример 3. Использование text-overflow
HTML5 CSS3 IE Cr Op Sa Fx
Результат данного примера показан на рис. 3.
Рис. 3. Текст с многоточием
Большим плюсом указанных методов служит тот момент, что градиент и многоточие не отображаются если текст короткий и целиком помещается в заданную область. Так что текст будет выводиться как обычно, когда он целиком виден на экране и обрезаться при уменьшении ширины элемента.
Есть ли решение добавить эллипсис на последней строке внутри div с высотой жидкости (20%)?
Я нашел функцию -webkit-line-clamp в CSS, но в моем случае номер строки будет зависеть от размера окна.
У меня есть этот JSFiddle, чтобы проиллюстрировать проблему. https://jsfiddle.net/96knodm6/
html css css3 ellipsis
15 ответов
Наконец-то я нашел решение сделать то, что хочу. Как p paragraphe и article обертка. Если вы хотите применить эллипсис к p в зависимости от высоты article (который также зависит от высоты окна), вам нужно получить height article , line-height p , а затем articleHeight/lineHeight , чтобы найти число line-clamp , которое можно добавить динамически тогда.
Единственное, что line-height должно быть объявлено в файле css.
Проверьте следующий код. Если вы измените высоту окна, значение line-clamp изменится. Может быть здорово создать плагин, нацеленный на это.
58 Michael_B [2015-10-11 05:50:00]
Если вы хотите применить многоточие (. ) к одной строке текста, CSS делает это несколько проще с text-overflow имущество. Это все еще немного сложно (из-за всех требований – см. Ниже), но text-overflow делает это возможным и надежным.
Если, однако, вы хотите использовать многоточие в многострочном тексте — как это было бы здесь, тогда не ожидайте, что получится весело. CSS не имеет стандартного метода для этого, и обходные пути поражаются и пропускаются.
Эллипсис для текста с одной строкой
С text-overflow эллипсис может применяться к одной строке текста. Необходимо выполнить следующие требования CSS:
- должен иметь width , max-width или flex-basis
- должен иметь white-space: nowrap
- должен иметь overflow со значением, отличным от visible
- должен быть display: block или inline-block (или функциональный эквивалент, например гибкий элемент).
Итак, это сработает:
НО, попробуйте удалить width или поместив overflow по умолчанию на visible или удалив white-space: nowrap , или используя что-то иное, кроме элемента контейнера блока, AND, эллипсис терпит неудачу.
Один большой вынос здесь: text-overflow: ellipsis не влияет на многострочный текст. (Только требование white-space: nowrap устраняет эту возможность.)
Эллипсис для многострочного текста
Поскольку CSS не имеет свойства для многоточия в многострочном тексте, были созданы различные обходные пути. Некоторые из этих методов можно найти здесь:
Пожалуйста, проверьте этот css для многоточия в многострочном тексте
CSS3-переполнение

Модуль CSS Overflow содержит функции CSS, связанные с обработкой прокручиваемого переполнения, отображаемого на визуальных носителях. CSS использует термин переполнение для описания содержимого блока, которое простирается за пределы одного из его краев, т.е. края области содержимого, поля, границы или отступа.
Управление переполнением
Поддержка браузерами
IE: 10
Edge: 12
Firefox: 52, 2 -moz
Chrome: 50, 4 -webkit-
Safari: 9, 3.1 -webkit-
Opera: 37, 11.5 -webkit-
iOS Safari: 9, 3.2 -webkit-
UC Browser for Android: 11.8
Chrome for Android: 73
Samsung Internet: 5, 4 -webkit-
1. Типы переполнения
Существует два типа переполнения, которое используется браузерами: переполнение эффектов рисования и прокручиваемое переполнение.
Первый тип переполнения представляет собой часть блока и его содержимое, которые создают визуальные эффекты за пределами рамки элемента. К визуальным эффектам относятся тень блока, рамки элемента, тень текста, нависающие глифы, контуры и т.д.
Прокручиваемое переполнение представляет собой набор элементов, выходящих за пределы области полей блока, для которых должен быть предусмотрен механизм прокрутки (полоса прокрутки, или скроллбар).
2. Прокрутка и обрезка переполнения: свойства overflow-x, overflow-y и overflow
Эти свойства определяют, будет ли содержимое блока, включая переполнение любых эффектов рисования, обрезано по краю области полей, и если это так, будет ли этот блок контейнером прокрутки, позволяющим пользователю прокручивать обрезанные части его содержимого. Применяются к блочным, гибким контейнерам и контейнерам-сеткам.
Свойство overflow-x определяет обработку переполнения в горизонтальном направлении (т.е. переполнение с левой и правой сторон блока), а свойство overflow-y определяет обработку переполнения в вертикальном направлении (т.е. переполнение с верхней и нижней сторон блока).
Свойства не наследуются.
overflow-x, overflow-y | |
---|---|
Значения: | |
visible | Значение по умолчанию. Содержимое не обрезается, а отображается поверх границ блока-контейнера. Возможно перекрытие соседних блоков. |
hidden | Содержимое блока обрезается без добавления какого-либо интерфейса прокрутки для просмотра содержимого вне области обрезки. |
scroll | Содержимое обрезается до области полей, при этом блок становится прокручиваемым контейнером. Если браузер использует механизм прокрутки, который виден на экране, например, полосу прокрутки, этот механизм отображается независимо от того, обрезано ли какое-либо его содержимое. Это позволяет избежать проблем с появлением и исчезновением полос прокрутки в динамической среде. Размеры контейнера при этом не меняются, а полоса прокрутки вставляется между внутренним краем границы и внешним краем поля элемента. |
auto | Браузер использует механизм прокрутки только при переполнении блока. |
initial | Устанавливает значение свойства в значение по умолчанию. |
inherit | Наследует значение свойства от родительского элемента. |
Синтаксис
overflow-x: visible;
overflow-x: hidden;
overflow-x: scroll;
overflow-y: auto;
overflow-x: inherit;
overflow-x: initial;
Свойство overflow — сокращенное свойство, которое задает значения overflow-x и overflow-y в указанном порядке. Если второе значение опущено, оно копируется из первого.
Содержимое блочных элементов может переполнять блок в случае, когда для блока явно задана высота и/или ширина. Без указания высоты блок будет растягиваться, чтобы вместить содержимое, кроме случаев, когда для блока задано позиционирование position: absolute; или position: fixed;. Текст может переполнять блок по высоте, изображения — по высоте и ширине.
overflow | |
---|---|
Значения: | |
visible | Значение по умолчанию. Содержимое не обрезается, а отображается поверх границ блока-контейнера. Возможно перекрытие соседних блоков. |
hidden | Содержимое блока обрезается без добавления какого-либо интерфейса прокрутки для просмотра содержимого вне области обрезки. Также предотвращает отображение фона или границ под плавающими элементами, для которых задано свойство float: left / right;. |
scroll | Содержимое обрезается до области полей, при этом блок становится прокручиваемым контейнером. Если браузер использует механизм прокрутки, который виден на экране, например, полосу прокрутки, этот механизм отображается независимо от того, обрезано ли какое-либо его содержимое. Это позволяет избежать проблем с появлением и исчезновением полос прокрутки в динамической среде. Размеры контейнера при этом не меняются, а полоса прокрутки вставляется между внутренним краем границы и внешним краем поля элемента. |
auto | Браузер использует механизм прокрутки только при переполнении блока. |
initial | Устанавливает значение свойства в значение по умолчанию. |
inherit | Наследует значение свойства от родительского элемента. |
Синтаксис
overflow: visible;
overflow: hidden;
overflow: scroll;
overflow: hidden scroll;
overflow: auto;
overflow: inherit;
overflow: initial;
3. Автоматическое многоточие
3.1. Многоточие при переполнении: свойство text-overflow
Свойство позволяет обрезать строчное содержимое в случае, когда оно не умещается в блок-контейнер, визуально обрезая его или отображая многоточием. Текст может переполниться, например, когда ему запрещается перенос, например, из-за white-space: nowrap или отдельное слово слишком длинное, чтобы уместиться.
Свойство работает только при задании следующих условий: должна быть определена ширина блока-контейнера, элемент должен иметь значения overflow: hidden и white-space: nowrap. Применяется только к блочным контейнерам.
Свойство не наследуется.
text-overflow | |
---|---|
Значения: | |
clip | Значение по умолчанию. Текст обрезается в пределе области содержимого, при этом может отобразиться лишь часть символа. |
ellipsis | Замещает текст, не уместившийся в блок, с помощью многоточия. |
initial | Устанавливает значение свойства в значение по умолчанию. |
inherit | Наследует значение свойства от родительского элемента. |
Синтаксис
text-overflow: clip;
text-overflow: ellipsis;
text-overflow: initial;
text-overflow: inherit;
По материалам CSS Overflow Module Level 3
CSS многоточие переполнения текста не отображается
У меня есть div с некоторым внутренним содержанием, которое мне нужно иметь многоточие, когда оно переполняется. Я делал это много раз на других элементах, но по какой-то причине это не ведет себя так, как ожидалось.
Кроме того, я специально оставил white-space:nowrap;
, потому что содержимое тогда не разбивается на следующую строку в пределах диапазона, в результате чего я вижу только 2-3 слова до начала многоточия. Я хотел бы, чтобы текст занимал всю высоту родительского контейнера, а затем имел многоточие для содержимого, которое существует за этими границами.
Вот рабочая демонстрация: http://jsfiddle.net/sadmicrowave/DhkSA/
CSS:
.flow-element{
position:absolute;
font-size:12px;
text-align:center;
width:75px;
height:75px;
line-height:70px;
border:1px solid #ccc;
}
.flow-element .inner{
position:absolute;
width:80%;
height:80%;
border:1px solid blue;
top:0px;
bottom:0px;
left:0px;
right:0px;
margin:auto;
text-align:center;
}
.flow-element .long{
float:left;
height:50px;
width:100%;
line-height:12px;
border:1px solid red;
text-overflow:ellipsis;
overflow:hidden;
}
HTML:
<a>
<div>
<span>Box 1 and some other content that should wrap and do some other stuff</span>
</div>
</a>
Может кто-нибудь, пожалуйста, помочь. Мне нужно отобразить как можно больше текста в пределах красного очерченного промежутка, имея многоточие, когда текстовое содержимое переполняет контейнер…
Заранее спасибо
css ellipsis css3Поделиться Источник sadmicrowave 29 марта 2012 в 18:48
4 Ответов
33
вы не можете применить text-overflow: ellipsis
к встроенным элементам (span), его можно использовать только с блочными элементами (div)
а также использовать white-space:nowrap;
при использовании text-overflow: ellipsis;
проверьте это, я преобразовал ваш внутренний промежуток в div, просто для доказательства концепции
http://jsfiddle.net/3CgcH/5/
я не знаю, почему вы использовали span, но в соответствии с вашей логикой вы можете внести изменения, как я предложил
Обновление:
кто-то подумает, что в вопросе, если я помещаю white-space: nowrap;
в элемент span, то text-overflow: ellipsis:
работает, так что, возможно, я ошибаюсь, но это не так, потому что вопроситель использовал float: left
в теге span, что означает, что тег span будет преобразован в блок box и работать как обычный элемент уровня блока, что также неправильно, потому что если вам нужно поведение элемента block, то используйте элемент уровня блока
Ссылка:
http://www.w3.org/TR/CSS2/visuren.html#propdef-float
http://dev.w3.org/csswg/css3-ui/#text-переполнение
Поделиться Saket Patel 29 марта 2012 в 18:54
0
Добавьте white-space:nowrap;
к вашему .inner div.
Поделиться huzzah 29 марта 2012 в 18:54
0
Добавить это:
white-space:nowrap;
к.проточный элемент .long
тогда срабатывает перелив-эллиспсис.
Поделиться Sven Bieder 29 марта 2012 в 18:56
0
Я думаю, что вы обнаружите, что проблема вызвана наличием text-align: center;
Поделиться Peter Presnell 22 марта 2013 в 21:31
CSS многоточие переполнения текста с несколькими элементами
Вот что я хочу сделать: Держите текст и кнопку в одной строке и выровняйте по центру При уменьшении размера экрана, всегда держите кнопку отображается во время переполнения текста: многоточие…
Многоточие переполнения текста с таблицей
У меня есть макет, который центрируется с помощью класса box-center. Теперь я хочу добавить многоточие переполнения текста, но оно больше не центрируется. .box-center { display: table; table-layout:…
Обнаружение переполнения текста CSS: многоточие в Firefox
Я пытаюсь обнаружить (через javascript), когда происходит переполнение текста. После долгих исследований у меня есть рабочее решение, за исключением любой версии Firefox:…
html canvas многоточие переполнения текста
Можно ли нарисовать текст на canvas, который имеет многоточие в конце текста, если текст не будет соответствовать доступной ширине и должен быть усечен? Спасибо.
многоточие переполнения текста не работает с динамической шириной
надеюсь, кто-нибудь сможет помочь. У меня есть 3 вложенных div. Родитель, дети и дети детей. Что я хочу сделать (мотив не имеет значения), так это то, что этот ребенок получает относительную ширину…
Как показать многоточие переполнения текста в середине текста
Я использую сетку кендо с фиксированной шириной. Если текст больше, то он показывает многоточие. Но я могу различать строки, основанные на конце строки. Из-за этого эффекта я не могу его найти….
CSS текст-многоточие переполнения не работает в сетке / Flex
Я не могу заставить многоточие переполнения текста работать в сетке css. Текст усечен, но точки с многоточием не отображаются. Вот мой css: .grid { display: grid; margin: auto; width: 90%;…
Многоточие переполнения текста на двух строках
Я знаю, что вы можете использовать комбинацию правил CSS, чтобы текст заканчивался многоточием (…) когда пришло время переполнения (выйти за пределы родительских границ). Можно ли (не стесняйтесь…
Определите, отображается ли многоточие при использовании -webkit-line-clamp для многострочного многоточия
Мы используем многострочный эллипсис CSS в соответствии с https://css-tricks.com/line-clampin/ . Мы хотим определить, отображается ли многоточие, и принять решение показать подсказку на основе того,…
многоточие не работает (flexbox)
Я пытаюсь поставить многоточие для переполнения текста: родитель: .grid-row { display: flex; } ребенок: .grid-cell { display: flex; flex-grow: 3; flex-basis: 0; align-items: center; padding: 10px;…
Как с помощью CSS скрыть текст, выходящий за блок: применение свойства webkit-line-clamp
От автора: когда свойство -webkit-line-clamp применяется к блоку текста (например, абзацу), текст можно ограничить указанным количеством строк (1 или более), и в конец последней видимой строки добавить многоточие (…). Таким образом, вы можете с помощью CSS скрыть текст, выходящий за блок.
.line-clamp-3 { /* Обязательные объявления: */ overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; /* Ограничиваем блок текста тремя строками */ -webkit-line-clamp: 3; }
.line-clamp-3 { /* Обязательные объявления: */ overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical;
/* Ограничиваем блок текста тремя строками */ -webkit-line-clamp: 3; } |
Примечание. Убедитесь, что элемент не имеет (нижнего) отступа, чтобы не допускать визуализации текстовых строк за пределами границ. Если вокруг усеченного текста требуется отступ, примените отступ к родительскому элементу.

Практический курс по верстке адаптивного сайта с нуля!
Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3
Узнать подробнееСвойство -webkit-line-clamp указывается в модуле CSS Overflow (раздел 5.1.1.) И уже поддерживается во всех основных браузерах, кроме Firefox, реализация недавно появилась в Firefox Nightly и может появиться в Firefox уже в июле (в версии 68).
Источник: https://webplatform.news
Редакция: Команда webformyself.

PSD to HTML
Практика верстки сайта на CSS Grid с нуля
Смотреть