Es posible limitar la salida a dos líneas de texto con CSS, si establece el line-height
y height
del elemento, y establece overflow:hidden;
:
#someDiv {
line-height: 1.5em;
height: 3em;
overflow: hidden;
}
--- jsFiddle DEMO ---
Alternativamente, puede usar CSS text-overflow
y white-space
propiedades para agregar puntos suspensivos, pero esto solo parece funcionar para una sola línea.
#someDiv {
line-height: 1.5em;
height: 3em;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
width: 100%;
}
Y una demostración:
--- jsFiddle DEMO ---
Lograr múltiples líneas de texto y puntos suspensivos parece ser el ámbito de javascript.
white-space: nowrap;
roto lo rompe, si lo comenta, funciona.Otra solución simple y rápida
.giveMeEllipsis { overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: N; /* number of lines to show */ line-height: X; /* fallback */ max-height: X*N; /* fallback */ }
La referencia a la pregunta y respuesta originales está aquí.
fuente
box-orient
está en desuso u obsoleto .mat-card-content
en unflexbox container
El mejor que he visto, que es solo CSS y con capacidad de respuesta, proviene del Blog de desarrolladores de Mobify - Elipsis de CSS: Cómo administrar elipsis de varias líneas en CSS puro :
Ejemplo de JS Fiddle
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: "\02026"; 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: -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); }
HTML:
<div class="ellipsis"> <div class="blah"> <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>
fuente
Creo que la solución de solo CSS se
text-overflow: ellipsis
aplica a una sola línea, por lo que no podrá seguir esta ruta:.yourdiv { line-height: 1.5em; /* Sets line height to 1.5 times text size */ height: 3em; /* Sets the div height to 2x line-height (3 times text size) */ width: 100%; /* Use whatever width you want */ white-space: normal; /* Wrap lines of text */ overflow: hidden; /* Hide text that goes beyond the boundaries of the div */ text-overflow: ellipsis; /* Ellipses (cross-browser) */ -o-text-overflow: ellipsis; /* Ellipses (cross-browser) */ }
¿Has probado http://tpgblog.com/threedots/ para jQuery?
fuente
display: block
ymin-height: 13px
ymax-height: 26px
para el ajuste de altura para un<td>
Solución CSS única para Webkit
// Only for DEMO $(function() { $('#toggleWidth').on('click', function(e) { $('.multiLineLabel').toggleClass('maxWidth'); }); })
.multiLineLabel { display: inline-block; box-sizing: border-box; white-space: pre-line; word-wrap: break-word; } .multiLineLabel .textMaxLine { display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; overflow: hidden; } /* Only for DEMO */ .multiLineLabel.maxWidth { width: 100px; }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <div class="multiLineLabel"> <span class="textMaxLine">This text is going to wrap automatically in 2 lines in case the width of the element is not sufficiently wide.</span> </div> <br/> <button id="toggleWidth">Toggle Width</button>
fuente
Solo CSS
line-height: 1.5; white-space: normal; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
fuente
Pruebe algo como esto: http://jsfiddle.net/6jdj3pcL/1/
<p>Here is a paragraph with a lot of text ...</p> p { line-height: 1.5em; height: 3em; overflow: hidden; width: 300px; } p::before { content: '...'; float: right; margin-top: 1.5em; }
fuente
Normalmente, un truncado de una línea es bastante simple
.truncate-text { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
El truncado de dos líneas es un poco más complicado, pero se puede hacer con css, este ejemplo está en sass.
@mixin multiLineEllipsis($lineHeight: 1.2rem, $lineCount: 2, $bgColor: white, $padding-right: 0.3125rem, $width: 1rem, $ellipsis-right: 0) { overflow: hidden; /* hide text if it is more than $lineCount lines */ position: relative; /* for set '...' in absolute position */ line-height: $lineHeight; /* use this value to count block height */ max-height: $lineHeight * $lineCount; /* max-height = line-height * lines max number */ padding-right: $padding-right; /* place for '...' */ white-space: normal; /* overwrite any white-space styles */ word-break: break-all; /* will break each letter in word */ text-overflow: ellipsis; /* show ellipsis if text is broken */ &::before { content: '...'; /* create the '...'' points in the end */ position: absolute; right: $ellipsis-right; bottom: 0; } &::after { content: ''; /* hide '...'' if we have text, which is less than or equal to max lines and add $bgColor */ position: absolute; right: 0; width: $width; height: 1rem * $lineCount; margin-top: 0.2rem; background: $bgColor; /* because we are cutting off the diff we need to add the color back. */ } }
fuente
Consulte http://jsfiddle.net/SWcCt/ .
Simplemente establezca
line-height
la mitad deheight
:line-height:20px; height:40px;
Por supuesto, para que
text-overflow: ellipsis
funcione también necesitas:overflow:hidden; white-space: pre;
fuente
text-overflow: ellipsis
solo funciona para cuadros en línea que desbordan el cuadro de línea. Sinwhite-space: pre
ellos, simplemente irían al cuadro de la siguiente línea. Y luego se necesita un salto de línea manual. No creo que haya una solución perfecta.Utilice el siguiente enlace para ajustarlo en dos líneas, consulte el enlace
Inserte puntos suspensivos (...) en la etiqueta HTML si el contenido es demasiado amplio
Eso necesita el siguiente jquery
http://www.jeremymartin.name/projects.php?project=jTruncate
fuente
La solución de @Asiddeen bn Muhammad funcionó para mí con una pequeña modificación en el CSS
.text { line-height: 1.5; height: 6em; white-space: normal; overflow: hidden; text-overflow: ellipsis; display: block; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
fuente