EN
CSS - cut with dots (...) overflowing text outside element
15 points
In this article, we're going to have a look at how in a simple way cut overflowing text from an element in pure CSS.
Quick solution:
xxxxxxxxxx
1
.element {
2
text-overflow: ellipsis;
3
white-space: nowrap;
4
overflow: hidden;
5
}
Note: JavaScript approach can be found here.
Simple preview:
The simplest way is to use text-overflow
style property with ellipsis
value.
This approach will be working only if:
- element size will be defined clearly (e.g. with
width
style property, when some parent will exceed element size or specific layout will force element to have proper size), - when text wrapping will be disabled (e.g.
white-space: nowrap
does it), - content overflowing will be disabled (e.g.
overflow: hidden
does it).
Note: presented in this article text shortcutting does not work if
display: flex
style property is used with element.To solve the
display: flex
problem, the text should be wrapped with additional element that uses thentext-overflo: ellipsis
.Check simple the problem solution here.
Runnable practical example:
xxxxxxxxxx
1
2
<html>
3
<head>
4
<style>
5
6
div.text {
7
padding: 5px;
8
width: 200px; /* <----------------- required depeding of layout or parent */
9
border: 1px solid red;
10
text-overflow: ellipsis; /* <------ required */
11
white-space: nowrap; /* <---------- required */
12
overflow: hidden; /* <------------- required */
13
}
14
15
</style>
16
</head>
17
<body>
18
<div class="text">
19
Very long text here, Very long text here,
20
Very long text here, Very long text here
21
</div>
22
</body>
23
</html>