text management

revision:


Content

text management tools text-overflow underline text truncation the white-space property


text management tools

top

hyphens:

none: no hyphen; overflow if needed
An extreme­ly long English word
manual: hyphen only at ‐ or ­ (if needed)
An extreme­ly long English word
auto: hyphens where the algorithm decides (if needed)
An extreme­ly long English word
code:
            <dl class="grid_B">
                <div>
                    <dt><code>none</code>: no hyphen; overflow if needed</dt>
                    <dd lang="en" class="none">An extreme­ly long English word</dd>
                </div>
                <div>
                    <dt><code>manual</code>: hyphen only at &hyphen; or &shy; (if needed)</dt>
                    <dd lang="en" class="manual">An extreme­ly long English word</dd>
                </div>
                <div>
                    <dt><code>auto</code>: hyphens where the algorithm decides (if needed)</dt>
                    <dd lang="en" class="auto">An extreme­ly long English word</dd>
                </div>
            </dl>
            <style>
                dd{width: 5.5vw; border: 1px solid black;}
                code{font-size:1.5vw; font-weight:bold;}
                dd.none{-webkit-hyphens: none; -ms-hyphens: none; hyphens: none;}
                dd.manual{-webkit-hyphens: manual;-ms-hyphens: manual; hyphens: manual;}
                dd.auto {-webkit-hyphens: auto; -ms-hyphens: auto; hyphens: auto;}
            </style>
        

letter-spacing

This text is having space between letters.

This is sentence number 1

This is sentence number 2

This is sentence number 3

code:
            <p style = "letter-spacing:5px;">This text is having space between letters.</p>
            <p style = "letter-spacing:7px;" >This is sentence number 1</p>
            <p style = "letter-spacing:9px;">This is sentence number 2</p>
            <p style = "letter-spacing:-1px;">This is sentence number 3</p>
        

tab-size:

no tab

default tab size of 8 characters wide

custom tab size of 3 characters wide

   3 spaces, equivalent to the custom tab size

code:
            <p>no tab</p>
            <p> & #0009; default tab size of 8 characters wide</p>
            <p class="custom"> & #0009;custom tab size of 3 characters wide</p>
            <p>& nbsp;& nbsp;& nbsp;3 spaces, equivalent to the custom tab size</p>
            <style>
            .custom {-moz-tab-size: 3; tab-size: 3;}
            </style>
        

text-align:

This will be right aligned.

This will be center aligned.

This will be left aligned.

code:
            <p style = "text-align:right;">This will be right aligned.</p>
            <p style = "text-align:center;">This will be center aligned.</p>
            <p style = "text-align:left;">This will be left aligned.</p>
        

text-align-last

Lorem Ipsum is dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.

code:
            <p id="one">Lorem Ipsum is dummy text. . . . </p>
            <style>
                .one{text-align: justify; -moz-text-align-last: right; text-align-last: right;}
            </style>
        

text-indent

This text will have first line indented by 1cm and this line will remain at its actual position. This is done by CSS text-indent property.

In my younger and more vulnerable years my father gave me some advice that I've been turning over in my mind ever since. 'Whenever you feel like criticizing anyone,' he told me, 'just remember that all the people in this world haven't had the advantages that you've had.'

code:
            <p style="text-indent:1cm;">This text will have . . . </p>
            <p style="text-indent:3cm;">In my younger and more . . . .</p>
        

text-justify

NONE
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc ornare maximus vehicula. Duis nisi velit, dictum id mauris vitae, lobortis pretium quam. Quisque sed nisi pulvinar, consequat justo id, feugiat leo. Cras eu elementum dui.

AUTO
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc ornare maximus vehicula. Duis nisi velit, dictum id mauris vitae, lobortis pretium quam. Quisque sed nisi pulvinar, consequat justo id, feugiat leo. Cras eu elementum dui.

DISTRIBUTE
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc ornare maximus vehicula. Duis nisi velit, dictum id mauris vitae, lobortis pretium quam. Quisque sed nisi pulvinar, consequat justo id, feugiat leo. Cras eu elementum dui.

INTER_WORD
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc ornare maximus vehicula. Duis nisi velit, dictum id mauris vitae, lobortis pretium quam. Quisque sed nisi pulvinar, consequat justo id, feugiat leo. Cras eu elementum dui.

INTER_CHARACTER
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc ornare maximus vehicula. Duis nisi velit, dictum id mauris vitae, lobortis pretium quam. Quisque sed nisi pulvinar, consequat justo id, feugiat leo. Cras eu elementum dui.

code:
                    <div>
                        <p class="none2">NONE<br>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc ornare maximus vehicula. Duis nisi velit, dictum id mauris vitae, lobortis pretium quam. 
                        Quisque sed nisi pulvinar, consequat justo id, feugiat leo. Cras eu elementum dui.</p>
                        <p class="auto2">AUTO<br>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc ornare maximus vehicula. Duis nisi velit, dictum id mauris vitae, lobortis pretium quam. 
                        Quisque sed nisi pulvinar, consequat justo id, feugiat leo. Cras eu elementum dui.</p>
                        <p class="dist">DISTRIBUTE<br>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc ornare maximus vehicula. Duis nisi velit, dictum id mauris vitae, lobortis pretium quam.
                        Quisque sed nisi pulvinar, consequat justo id, feugiat leo. Cras eu elementum dui.</p>
                        <p class="word">INTER_WORD<br>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc ornare maximus vehicula. Duis nisi velit, dictum id mauris vitae, lobortis pretium quam.
                        Quisque sed nisi pulvinar, consequat justo id, feugiat leo. Cras eu elementum dui.</p>
                        <p class="char">INTER_CHARACTER<br>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc ornare maximus vehicula. Duis nisi velit, dictum id mauris vitae, lobortis pretium quam.
                         Quisque sed nisi pulvinar, consequat justo id, feugiat leo. Cras eu elementum dui.</p>
                    </div>
                    <style>
                        .none2{font-size: 1vw; border: 1px solid green; padding: 1vw; width: 95%; margin: 1vw auto; text-align: justify; text-justify: none;}
                        .auto2{font-size: 1vw; border: 1px solid green; padding: 1vw; width: 95%; margin: 1vw auto; text-align: justify; text-justify: auto;}
                        .dist{font-size: 1vw; border: 1px solid green; padding: 1vw; width: 95%; margin: 1vw auto; text-align: justify; text-justify: distribute;}
                        .word{font-size: 1vw; border: 1px solid green; padding: 1vw; width: 95%; margin: 1vw auto; text-align: justify; text-justify: inter-word;}
                        .char{font-size: 1vw; border: 1px solid green; padding: 1vw; width: 95%; margin: 1vw auto; text-align: justify; text-justify: inter-character;}
                    </style>
                

text-transform

This will be capitalized

This will be in uppercase

This will be in lowercase

code:
            <p style = "text-transform:capitalize;">This will be capitalized</p>
            <p style = "text-transform:uppercase;">This will be in uppercase</p>
            <p style = "text-transform:lowercase;">This will be in lowercase</p>
        

white-space

This text has a line break and the white-space pre setting
tells the browser to honor it just like the HTML pre tag.

code:
            <style>
                <p style = "white-space:pre;">This text has a line break and the white-space pre setting <br>
                tells the browser to honor it just like the HTML pre tag.</p>
            </style>
        

word-break

NORMAL
Thisissomeveryveryverylong word. Words will break according to usual rules.

KEEP_ALL
Thisissomeveryveryverylong word. This text will-break-at-hyphens.

BREAK_ALL
Thisissomeveryveryverylong word. This text will break at any character.

code:
            <p class="a">NORMAL<br> Thisissomeveryveryverylong word. Words will break according to usual rules.</p>
            <p class="b">KEEP_ALL<br>Thisissomeveryveryverylong word. This text will-break-at-hyphens.</p>
            <p class="c">BREAK_ALL<br>Thisissomeveryveryverylong word. This text will break at any character.</p>
            <style>
                p.a {width: 10vw; border: 1px solid #000000;  word-break: normal;}
                p.b {width: 10vw; border: 1px solid #000000;word-break: keep-all;}
                p.c {width: 10vw; border: 1px solid #000000;word-break: break-all;}
            </style>
        

word-spacing

This text is having space between words.

code:
            <style>
                <p style = "word-spacing:5px;">This text is having space between words.</p>
            </style>
        


text-overflow

top

The text-overflow CSS property specifies how overflowed content that is not displayed should be signaled to the user. It can be clipped, display an ellipsis (...), or display a custom string. Both of the following properties are required for text-overflow:

"white-space: nowrap;"

"overflow: hidden;"

The "text-overflow property" only affects content that is overflowing a block container element in its inline progression direction (not text overflowing at the bottom of a box, for example).

syntax

text-overflow: clip|ellipsis|string|initial|inherit;

property values:

clip: default value; the text is clipped and not accessible.

ellipsis: render an ellipsis ("...") to represent the clipped text.

string: render the given string to represent the clipped text.

initial: sets this property to its default value.

inherit: inherits this property from its parent element.

The text-overflow property may be specified using one or two values. If one value is given, it specifies overflow behavior for the end of the line (the right end for left-to-right text, the left end for right-to-left text). If two values are given, the first specifies overflow behavior for the left end of the line, and the second specifies it for the right end of the line.

syntax examples:

text-overflow: clip;
text-overflow: ellipsis ellipsis;
text-overflow: ellipsis " [..]";

/* Global values */
text-overflow: inherit;
text-overflow: initial;
text-overflow: revert;
text-overflow: unset;

text-overflow

The following two divs contains a text that will not fit in the box.

text-overflow: clip (default):

Hello world!

text-overflow: ellipsis:

Hello world!

text-overflow: "----" (user defined string):

Hello world!

Note: The text-overflow: "string" only works in Firefox.

code:
            <style>
                .a, .b, .c{margin-left:4vw;}
                div.a {white-space: nowrap; width: 5vw; overflow: hidden; text-overflow: clip;
                        border: 1px solid #000000;}
                div.b {white-space: nowrap; width: 5vw; overflow: hidden; text-overflow: ellipsis;     
                border: 1px solid #000000;}
                div.c {white-space: nowrap; width: 5vw; overflow: hidden; text-overflow: "----";
                    border: 1px solid #000000;}
            </style>
            <p class="spec">The following two divs contains a text that will not fit in the box.</p>
            <h4>text-overflow: clip (default):</h4>
            <div class="a">Hello world!</div>
            <h4>text-overflow: ellipsis:</h4>
            <div class="b">Hello world!</div>
            <h4>text-overflow: "----" (user defined string):</h4>
            <div class="c">Hello world!</div>
            <p class="spec"><strong>Note:</strong> The text-overflow: "<em>string</em>" only 
            works in Firefox.</p>
        

text-overflow

clip clip

Lorem ipsum dolor sit amet, consectetur adipisicing elit.

clip ellipsis

Lorem ipsum dolor sit amet, consectetur adipisicing elit.

ellipsis ellipsis

Lorem ipsum dolor sit amet, consectetur adipisicing elit.

ellipsis " [..]"

Lorem ipsum dolor sit amet, consectetur adipisicing elit.

code:
            <style>
                .formatting p {margin-left:2vw; width: 20vw; border: 1px solid; padding: 0.2vw 0.5vw;
                /* Both of the following are required for text-overflow */ white-space: nowrap;
                overflow: scroll;}
                .overflow-clip-clip {text-overflow: clip clip;}
                .overflow-clip-ellipsis {text-overflow: clip ellipsis;}
                .overflow-ellipsis-ellipsis {text-overflow: ellipsis ellipsis;}
                .overflow-ellipsis-string {text-overflow: ellipsis " [..]";}
            </style>
            <script>    
                // Scroll each paragraph so the start is also hidden
                const paras = document.querySelectorAll("p");

                for (let para of paras) {
                para.scroll(100, 0);
                }
            </script>             
            <div class="formatting">
                <pre style="margin-left:3vw; border: none">clip clip</pre>
                <p class="spec overflow-clip-clip; border: none">Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
                <pre style="margin-left:3vw; border: none;">clip ellipsis</pre>
                <p class="spec overflow-clip-ellipsis; border: none">Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
                <pre style="margin-left:3vw; border: none;">ellipsis ellipsis</pre>
                <p class="spec overflow-ellipsis-ellipsis; border: none">Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
                <pre style="margin-left:3vw; border: none;">ellipsis " [..]"</pre>
                <p class="spec overflow-ellipsis-string; border: none">Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
            </div>
        


underline

top

The text-decoration CSS property is used to decorate the content of the text. It can add lines above, under, and through the text. It decorates the text with several kinds of lines. It is the shorthand for "text-decoration-line", "text-decoration-color", and "text-decoration-style".

The property text-decoration-line is used to underline the text. It has three values that are "overline", "underline", or "line-through". The value "underline" is used to underline the text in CSS and draws the underline beneath the inline text.

There is no CSS property to apply an underline only to individual words in a sentence or an element with multiple words. The best way to achieve this is by wrapping the underlined words in a span element and then apply the underline to those spans.

However, the default underline is inconsistent across browsers. Each browser chooses its own default thickness and vertical position (offset from the baseline) for the underline.

There are two new, widely supported CSS properties that allow to precisely define the thickness and offset for our underlines:

the text-decoration-thickness property sets the stroke thickness of the decoration line that is used on text in an element.
the text-underline-offset property sets the distance of text underlines from their initial position. Once you apply an underline for an element using text-decoration with the value of underline, you can say how far that line should be from your text using the "text-underline-offset property".

With these properties, we can create consistent underlines even across two very different browsers, such as the Gecko-based Firefox on Android and the WebKit-based Safari on macOS.

syntax: text-decoration-thickness{ auto | from-font | length | percentage;}

property values:

auto: (default) allows the browser to specify an appropriate thickness for the text decoration line.

from-font: if the first available font has metrics specifying a preferred thickness, it uses that thickness; otherwise it behaves like the auto value.

length: any valid length with a unit specifies the thickness of text decoration lines as a fixed length. This replaces any information in the font and the browser default.

percentage: specifies the thickness of text decoration lines as a percentage of 1em in the element's font.

initial: the default setting of the property, which is auto.

inherit: adopts the decoration thickness value of the parent.

unset: removes the current thickness from the element.

syntax examples

            /* Single keyword */
            text-decoration-thickness: auto;
            text-decoration-thickness: from-font;

            /* length */
            text-decoration-thickness: 0.1em;
            text-decoration-thickness: 3px;

            /* percentage */
            text-decoration-thickness: 10%;

            /* Global values */
            text-decoration-thickness: inherit;
            text-decoration-thickness: initial;
            text-decoration-thickness: revert;
            text-decoration-thickness: unset;
        

After setting a decoration for an element, all its children will have that decoration too.

For this property, a length will inherit as a fixed value, and will not scale with the font. A percentage will inherit as a relative value and, therefore, scale with changes in the font as it inherits.

syntax: text-underline-offset{ auto | from-font | length | percentage;}

property values:

auto: (default) the browser will specify an appropriate offset for underlines.

length: any valid length with a specified unit (including negative values). This replaces any information in the font and the browser default.

percentage: specifies the offset of underlines as a percentage of 1em in the element's font

initial: the default setting of the property, which is auto.

inherit: adopts the underline offset value of the parent.

unset: removes the current offset from the element.

syntax examples

            /* Single keyword */
            text-underline-offset: auto;

            /* length */
            text-underline-offset: 0.1em;
            text-underline-offset: 3px;

            /* percentage */
            text-underline-offset: 20%;

            /* Global values */
            text-underline-offset: inherit;
            text-underline-offset: initial;
            text-underline-offset: revert;
            text-underline-offset: unset;
        

text-underline-offset is not part of the shorthand of text-decoration. It doesn't work on other text-decoration lines, such as line-through or overline. Negative values are accepted, which offsets the underline inward. Once you set a decoration for an element, all its children will have that decoration too.

underline

Welcome to my website

Hi, welcome to this website. This site is developed to let you know more about my favorite activities: photos and learning coding. This is an early endeavor from my side and I'm well aware that this web site can be improved.

code:
            <style>
                h4 {margin-left: 4vw;color: blue;}     
                #p1 {font-size: 1.2vw; text-decoration: underline; text-decoration-color: blue;}     
            </style>
            <h4 class="h4">Welcome to my website</h4>     
            <div>     
                <p id="p1">  Hi, welcome to this website. This site is developed to let you know more  about my favorite activities:
                photos and learning coding. This is an early endeavor from my side and I'm well aware that this web site can be improved.
                </p>     
            </div>   
        

underline

Salutations, my friend

code:
            <div>
                <style>
                    .h4-1 {display: block; font-size: 2em; color: hsl(207, 90%, 54%); text-decoration: underline solid blue 1px;}
                    @supports not (text-decoration: solid blue 1px) {
                        h4::after {content: "Your browser doesn't support text-decoration-thickness in text-decoration."; 
                        display: block; color: #e43; margin-top: 1vw; font-weight: bold;text-decoration: unset; font-size: 1vw;}
                    }
                </style>
                <h4>Salutations, <span>my friend</span></h4>
            </div>
        

underline

Here's some text with an offset wavy red underline!


This text has lines both above and below it. Only the bottom one is offset.

code:
            <style>
                .oneline {text-decoration: underline wavy red; text-underline-offset: 1em;}
                .twolines {text-decoration-color: purple;  text-decoration-line: underline 
                    overline;}
            </style>
            <p class="spec oneline">Here's some text with an offset wavy red underline!</p>
            <br>
            <p class="spec twolines">This text has lines both above and below it. Only the
            bottom one is offset.</p>
        


text truncation

top

1- flexible truncation

In my experience there is no such thing as luck. – Obi-Wan Kenobi

code:
            <style>
                h4-2 {width: 20vw; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; padding: 2vw; resize: horizontal; background: teal; color: #fff; font-family: Roboto, "Helvetica Neue",Arial,sans-serif;
                display: flex; justify-content: left; align-items: left;}
            </style>
        

2- using CSS «line-clamp» to truncate text to a set number of lines

Morbi rutrum lectus turpis, sit amet sollicitudin eros condimentum vitae. Integer consequat eros vel tortor tempor, et vulputate turpis pretium. Suspendisse vel metus sem. Aenean sollicitudin luctus est ac gravida. Curabitur eros tellus, scelerisque sit amet suscipit consequat, laoreet at quam. Nullam massa ante, tincidunt quis metus ut, consequat facilisis risus. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus.

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec venenatis velit sit amet dui semper dignissim. More dynamic text here.

code:
            <div>
                <div class="line-clamp">
                    <p>Morbi rutrum lectus turpis, sit amet sollicitudin eros condimentum vitae... nascetur ridiculus mus.</p>
                </div>
                <p class="line-clamp2"> Lorem ipsum dolor sit amet, consectetur adipiscing elit... dignissim. More dynamic text here.</p>
            </div>
            <style>
                .line-clamp{width: 30vw; overflow: hidden; display: -webkit-box; display: block; -webkit-line-clamp: 4;-webkit-box-orient: vertical; line-clamp:4; margin: 0 auto;}
                .line-clamp2{width: 20vw; overflow: hidden; display: -webkit-box; display: block; -webkit-line-clamp: 3;-webkit-box-orient: vertical; line-clamp:3; margin: 0 auto;}
            </style>
        

3- using CSS variables to truncate text to a set number of lines

Morbi rutrum lectus turpis, sit amet sollicitudin eros condimentum vitae. Integer consequat eros vel tortor tempor, et vulputate turpis pretium. Suspendisse vel metus sem. Aenean sollicitudin luctus est ac gravida. Curabitur eros tellus, scelerisque sit amet suscipit consequat, laoreet at quam. Nullam massa ante, tincidunt quis metus ut, consequat facilisis risus. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus.Morbi rutrum lectus turpis, sit amet sollicitudin eros condimentum vitae. Integer consequat eros vel tortor tempor, et vulputate turpis pretium. Suspendisse vel metus sem. Aenean sollicitudin luctus est ac gravida. Curabitur eros tellus, scelerisque sit amet suscipit consequat, laoreet at quam. Nullam massa ante, tincidunt quis metus ut, consequat facilisis risus. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus.

code:
            <style>
                .truncate-overflow{--max-lines: 4; position: relative; width: 30vw; max-height: calc(var(--lh) * var(--max-lines)); overflow: hidden; margin: 0 auto;}
                .truncate-overflow::before{position: absolute; content: "..."; bottom: 0; right: 1vw; z-index: 1;}
                .truncate-overflow::after{content: ""; position: absolute; bottom: 0; right: 1vw;  width: 1vw; height: 1vw; background: skyblue; z-index: 0;}
            </style>
        

4- using different techniques to truncate text

This is a Longer Text...
1. This is a long string that is OK to truncate. Do it. Thank you.
2. This is a long string that is OK to truncate. Do it. Thank you.
3. This is a long string that is OK to truncate. Do it. Thank you.
code:
            <div class="truncate-overflow">
                <p>Morbi rutrum lectus turpis, sit amet sollicitudin eros condimentum vitae. Integer consequat eros vel tortor tempor, et vulputate turpis pretium. Suspendisse vel metus sem. 
                Aenean sollicitudin luctus est ac gravida. Curabitur eros tellus, scelerisque sit amet suscipit consequat, laoreet at quam. Nullam massa ante, tincidunt quis metus ut, consequat 
                facilisis risus. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus.Morbi rutrum lectus turpis, sit amet sollicitudin eros condimentum vitae. 
                Integer consequat eros vel tortor tempor, et vulputate turpis pretium. Suspendisse vel metus sem. Aenean sollicitudin luctus est ac gravida. Curabitur eros tellus, scelerisque sit 
                amet suscipit consequat, laoreet at quam. Nullam massa ante, tincidunt quis metus ut, consequat facilisis risus. Orci varius natoque penatibus et magnis dis parturient montes, 
                nascetur ridiculus mus.</p>
            </div>
            <style>
                .truncate-overflow{--max-lines: 4; position: relative; width: 30vw; max-height: calc(var(--lh) * var(--max-lines)); overflow: hidden; margin: 0 auto;}
                .truncate-overflow::before{position: absolute; content: "..."; bottom: 0; right: 1vw; z-index: 1;}
                .truncate-overflow::after{content: ""; position: absolute; bottom: 0; right: 1vw; width: 1vw; height: 1vw; background: skyblue; z-index: 0;}
            </style>
            <div class="spec">
                <summary>code:</summary>
                <pre>
                    <style>
                        .truncate-overflow{--max-lines: 4; position: relative; width: 30vw; max-height: calc(var(--lh) * var(--max-lines)); overflow: hidden; margin: 0 auto;}
                        .truncate-overflow::before{position: absolute; content: "..."; bottom: 0; right: 1vw; z-index: 1;}
                        .truncate-overflow::after{content: ""; position: absolute; bottom: 0; right: 1vw;  width: 1vw; height: 1vw; background: skyblue; z-index: 0;}
                    </style>
                </pre>
            </div><br>
            <h3>4- using different techniques to truncate text</h3>
            <div data-title="This is a Longer text which needs to be shown with ... and show full on hover">This is a Longer Text...</div>
            <div class="flex-parent">
                <div class="flex-child long-and-truncated">
                    1. This is a long string that is OK to truncate. Do it. Thank you.
                </div>
                <div class="flex-child short-and-fixed">
                    <div></div>
                    <div></div>
                    <div></div>
                </div>
            </div>
            <div>
                <div class="flex-parent has-child">
                    <div class="flex-child long-and-truncated-with-child">
                        <h5>2. This is a long string that is OK to truncate. Do it. Thank you.</h5>
                    </div>
                    <div class="flex-child short-and-fixed">
                        <div></div>
                        <div></div>
                        <div></div>
                    </div>
                </div>
            </div>
            <div class="flex-parent has-child">
                <div class="flex-child long-and-truncated-with-child-corrected">
                    <h5>3. This is a long string that is OK to truncate. Do it. Thank you.</h5>
                </div>
                <div class="flex-child short-and-fixed">
                    <div></div>
                    <div></div>
                    <div></div>
                </div>
            </div>
            <style>
                [data-title] {font-size: 1vw; position: relative; cursor: help; margin-left: 3vw; margin-bottom: 4vw;}
                [data-title]:hover::before {content: attr(data-title); position: absolute;  bottom: -4.6vw; padding: 1vw; background: #000; color: #fff; font-size: 1vw;  white-space: nowrap;}
                [data-title]:hover::after {content: ''; position: absolute; bottom: -1.2vw; left: 0.8vw; border: 0.8vw solid transparent; border-bottom: 0.8vw solid #000;}
                .flex-parent{display: flex; align-items: center; padding: 1vw; margin: 1vw 0; width: 30vw;}
                .flex-child{margin-left: 2vw;}
                .long-and-truncated {flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}
                .long-and-truncated-with-child{flex: 1;}
                .long-and-truncated-with-child h5{white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}
                .short-and-fixed{ white-space: nowrap;}
                .short-and-fixed > div { width: 1vw; height: 1vw; border-radius: 0.5vw;  background: lightgreen; display: inline-block;}
                .long-and-truncated-with-child-corrected{flex: 1; min-width: 0; }
                .long-and-truncated-with-child-corrected h5{white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}    
            </style>
        

5- using JavaScript to truncate text

Different functions used to enable truncation

code:
            <div>
                <div id="one"></div>
                <div id="two"></div>
                <div id="three"></div>        
            </div>
            <script>
                text_truncate = function(str, length, ending) {
                    if (length == null) {
                        length = 100;
                    }
                    if (ending == null) {
                        ending = '...';
                    }
                    if (str.length > length) {
                        return str.substring(0, length - ending.length) + ending;
                    } else {
                        return str;
                    }
                };
                res = text_truncate("Lorem Ipsum placeholder text in any number of characters, 
                words sentences or paragraphs", 13);
                res1 = text_truncate("Lorem Ipsum placeholder text in any number of characters, 
                words sentences or paragraphs", 19);
                res2 = text_truncate("Lorem Ipsum placeholder text in any number of characters, 
                words sentences or paragraphs", 23);
                document.getElementById("one").innerHTML = res;
                document.getElementById("two").innerHTML = res1;
                document.getElementById("three").innerHTML = res2;
            </script>
        

code:
            <div>
                <div id="four"></div>
                <div id="five"></div>
                <div id="six"></div>
            </div>
            <script>
                function truncateString(str, num) {
                    if (num > str.length){
                    return str;
                    } else{
                    str = str.substring(0,num);
                    return str+"...  ";
                    }
                }
                res3 = truncateString("What goes up has to come down. Gravity at its best", 11);
                res4 = truncateString("What goes up has to come down. Gravity at its best", 21);
                res5 = truncateString("What goes up has to come down. Gravity at its best", 31);
                document.getElementById("four").innerHTML = res3
                document.getElementById("five").innerHTML = res4
                document.getElementById("six").innerHTML = res5
            </script>
        

code:
            <div id="seven" style="margin-left: 3vw;"></div>
            <script>
                function truncateString(str, num) {
                    if (str.length <= num) {
                    return str
                }
                    return str.slice(0, num) + '...'
                }
                resA = truncateString("What goes up has to come down. Gravity at its best", 9);
                document.getElementById("seven").innerHTML = resA
            </script>
        

code:
            <div>
                <div id="eight"></div>
                <div id="nine"></div>
            </div>
            <script>
                function truncate(str, no_words) {
                    return str.split(" ").splice(0,no_words).join(" ");
                    }
                    document.getElementById("eight").innerHTML = truncate('The quick brown fox jumps 
                    over the lazy dog', 4);
                    document.getElementById("nine").innerHTML = truncate('The quick brown fox jumps 
                    over the lazy dog', 7) + "...";
            </script>
        


the white-space property

top

The white-space property specifies how white-space inside an element is handled.

wrap values

white-space: nowrap:

This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text. This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.

white-space: normal:

This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text. This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.

white-space: pre:

This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text.

white-space: pre-wrap:

This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text.

white-space: pre-line:

This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text.

white-space: break-spaces:

This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text. This is some text.

code:
        <div class="white">
            <h4>white-space: nowrap:</h4>
                <p class="a">
                This is some text. This is some text. This is some text.<br>
                This is some text. This is some text. This is some text.
                This is some text. This is some text. This is some text.<br>
                This is some text. This is some text. This is some text.
                </p>
            <h4>white-space: normal:</h4>
                <p class="b">
                This is some text. This is some text. This is some text.<br>
                This is some text. This is some text. This is some text.
                This is some text. This is some text. This is some text.<br>
                This is some text. This is some text. This is some text.
                </p>
            <h4>white-space: pre:</h4>
                <p class="c">
                This is some text. This is some text. This is some text.
                This is some text. This is some text. This is some text.
                This is some text. This is some text. This is some text.
                This is some text. This is some text. This is some text.
                </p>
            <h4>white-space: pre-wrap:</h4>
                <p class="d">
                This is some text. This is some text. This is some text.
                This is some text. This is some text. This is some text.
                This is some text. This is some text. This is some text.
                This is some text. This is some text. This is some text.
                </p>
            <h4>white-space: pre-line:</h4>
                <p class="e">
                This is some text. This is some text. This is some text.
                This is some text. This is some text. This is some text.
                This is some text. This is some text. This is some text.
                This is some text. This is some text. This is some text.
                </p>
            <h4>white-space: break-spaces:</h4>
                <p class="f">
                This is some text. This is some text. This is some text.
                This is some text. This is some text. This is some text.
                This is some text. This is some text. This is some text.
                This is some text. This is some text. This is some text.
                </p>
        </div>
        <style>
            .white{width:30vw;}
            p.a{white-space: nowrap;}
            p.b{white-space: normal;}
            p.c{white-space: pre;}
            p.d{white-space: pre-wrap;}
            p.e{white-space: pre-line;}
            p.f{white-space: break-spaces;}
        </style>
    

The white-space property with JavaScript

Click the "Try it" button to make sure that the text inside the DIV element never wraps:

Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.
code:
        <div>
            <p><b>1_</b> Click the "Try it" button to make sure that the text inside the DIV element never wraps:</p>
                <button onclick="whiteSpace()">Try it</button>
                <button onclick="reset()">Reset</button>
                <div class="spec-2" id="myDIV">Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.</div>
        </div>
        <style>
            #myDIV {width: 30vw; height: 10vw; background-color: lightblue; border: 0.1vw solid black;}
            button{background-color:salmon; font-size: 1vw; width: 13vw;}
        </style>
        <script>
            function whiteSpace() {
            document.getElementById("myDIV").style.whiteSpace = "nowrap";
            }
            function reset(){
                document.getElementById('myDIV').style.whiteSpace = "normal";
            }
        </script>
    

This is some text. This is some text. This is some text. This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text. This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text. This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text. This is some text. This is some text. This is some text.

code:
        <div id="myDiv1" class="spec" style="white-space:nowrap;"> 
            This is some text. This is some text. This is some text.
            This is some text. This is some text. This is some text.<br>
            This is some text. This is some text. This is some text.
            This is some text. This is some text. This is some text.<br>
            This is some text. This is some text. This is some text.
            This is some text. This is some text. This is some text.<br>
            This is some text. This is some text. This is some text.
            This is some text. This is some text. This is some text.
        </div>
        <br>
        <button id="button1" type="button" onclick="whiteSpace1()">
        Return the whiteSpace property (alert!!)</button>
        <style>
            #myDIV1 {width: auto; height: 20vw; background-color: lightblue;
                    border: 0.1vw solid black;}
            #button1{background-color:salmon; font-size: 1vw; width: 23vw;}
        </style>
        <script>
            function whiteSpace1() {
                alert(document.getElementById("myDiv1").style.whiteSpace);
            }
        </script>
    

3_ Lorem ipsum sit dicunt verterem dissentiet eu. Cu vero suscipiantur deterruisset mea, nostro nonummy reprimique sea id.
Id pri fabellas quaestio delicatissimi, eum at dictas patrioque constituam, ius ut elit legimus eloquentiam.
Ut mei omnium oblique, est vero cibo nonummy te.

code:
        <div>
            <div id="myDiv2"><b>3_</b> Lorem ipsum sit dicunt verterem dissentiet eu. Cu vero suscipiantur deterruisset mea, nostro nonummy reprimique sea id.<br /> Id pri fabellas quaestio delicatissimi, 
            eum at dictas patrioque constituam, ius ut elit legimus eloquentiam.<br /> Ut mei omnium oblique, est vero cibo nonummy te.</div>
            <br />
            <label for="whitespace"></label>
            <select id="whitespace" size="3" onchange="ChangeWhiteSpace (this);">
                <option selected="selected" />normal
                <option />nowrap
                <option />pre
            </select>
        </div>
        <style>
            #myDiv2{width:24vw; border:1px solid #FF0000; white-space:normal;}
            select{width: 10vw; background-color: salmon;}
        </style>
        <script>
            function ChangeWhiteSpace (selectTag) {
                // Returns the index of the selected option
                var whichSelected = selectTag.selectedIndex;
                // Returns the text of the selected option
                var spaceValue = selectTag.options[whichSelected].text;
                var div = document.getElementById ("myDiv2");
                div.style.whiteSpace = spaceValue;
            }
        </script>