Limite la longitud del texto a n líneas usando CSS

Es posible limitar una longitud de texto a “n” líneas usando CSS (o cortarlo cuando se desborda verticalmente).

text-overflow: ellipsis; solo funciona para 1 línea de texto.

texto original:

Ultrices natoque mus mattis, aliquam, cras en pellentesque
tincidunt elit purus lectus, vel ut aliquet, elementum nunc
nunc rhoncus placerat urna! ¡Siéntate! Ut penatibus turpis
mus tincidunt! Dapibus sed aenean, magna sagittis, lorem velit

salida deseada (2 líneas):

Ultrices natoque mus mattis, aliquam, cras en pellentesque
tincidunt elit purus lectus, vel ut aliquet, elementum …

Hay una manera, pero es solo webkit. Sin embargo, cuando combina esto con line-height: X; y max-height: X*N; , también funcionará en otros navegadores, simplemente sin elipsis.

 .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 */ } 

Demostración: http://jsfiddle.net/csYjC/1131/

Lo que puedes hacer es lo siguiente:

 .max-lines { display: block; /* or inline-block */ text-overflow: ellipsis; word-wrap: break-word; overflow: hidden; max-height: 3.6em; line-height: 1.8em; } 

donde max-height: = line-height: × en em .

Por lo que puedo ver, esto sería posible solo usando height: (some em value); overflow: hidden height: (some em value); overflow: hidden e incluso entonces no tendría la fantasía ... al final.

Si eso no es una opción, creo que es imposible sin un preprocesamiento del lado del servidor (difícil porque el flujo de texto es imposible de predecir de manera confiable) o jQuery (posible pero probablemente complicado).

Solución de trabajo entre navegadores

Este problema nos ha estado afectando a todos durante años …

Para ayudar en todos los casos, he presentado el enfoque de solo CSS, y un enfoque jQuery en caso de que las advertencias de css sean un problema.

Aquí hay una solución de CSS única que surgió que funciona en todas las circunstancias, con algunas advertencias menores.

Los conceptos básicos son simples, oculta el desbordamiento del tramo y establece la altura máxima en función de la altura de la línea como lo sugiere Eugene Xa.

Luego hay una pseudoclase después del div que contiene que coloca la elipsis muy bien.

Advertencias

Esta solución siempre colocará la elipsis, independientemente de si la necesita.

Si la última línea termina con una oración final, terminarás con cuatro puntos …

Deberá estar contento con la alineación de texto justificada.

Las elipsis estarán a la derecha del texto, que puede verse descuidado.

Code + Snippet

jsfiddle

 .text { position: relative; font-size: 14px; color: black; width: 250px; /* Could be anything you like. */ } .text-concat { position: relative; display: inline-block; word-wrap: break-word; overflow: hidden; max-height: 3.6em; /* (Number of lines you want visible) * (line-height) */ line-height: 1.2em; text-align:justify; } .text.ellipsis::after { content: "..."; position: absolute; right: -12px; bottom: 4px; } /* Right and bottom for the psudo class are px based on various factors, font-size etc... Tweak for your own needs. */ 
 
Lorem ipsum dolor sit amet, nibh eleifend cu his, porro fugit mandamus no mea. Sit tale facete voluptatum ea, ad sumo altera scripta per, eius ullum feugait id duo. At nominavi pericula persecuti ius, sea at sonet tincidunt, cu posse facilisis eos. Aliquid philosophia contentiones id eos, per cu atqui option disputationi, no vis nobis vidisse. Eu has mentitum conclusionemque, primis deterruisset est in. Virtute feugait ei vim. Commune honestatis accommodare pri ex. Ut est civibus accusam, pro principes conceptam ei, et duo case veniam. Partiendo concludaturque at duo. Ei eirmod verear consequuntur pri. Esse malis facilisis ex vix, cu hinc suavitate scriptorem pri.

La solución de este hilo es usar el plugin jquery dotdotdot . No es una solución CSS, pero le ofrece muchas opciones para enlaces “leer más”, cambio de tamaño dynamic, etc.

Actualmente no puedes, pero en el futuro podrás utilizar text-overflow:ellipis-lastline . Actualmente está disponible con el prefijo del proveedor en Opera 10.60+: ejemplo

La siguiente clase de CSS me ayudó a obtener puntos suspensivos de dos líneas.

  .two-line-ellipsis { padding-left:2vw; text-overflow: ellipsis; overflow: hidden; width: 325px; line-height: 25px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; padding-top: 15px; } 

Realmente me gusta line-clamp, pero todavía no tengo soporte para firefox … así que voy con un cálculo matemático y simplemente oculto el desbordamiento

 .body-content.body-overflow-hidden h5 { max-height: 62px;/* font-size * line-height * lines-to-show(4 in this case) 63px if you go with jquery */ overflow: hidden; } .body-content h5 { font-size: 14px; /* need to know this*/ line-height:1,1; /*and this*/ } 

ahora digamos que quieres eliminar y agregar esta clase a través de jQuery con un enlace, necesitarás tener un píxel extra para que la altura máxima sea de 63 px, esto se debe a que debes verificar siempre si la altura es mayor que 62px, pero en el caso de 4 líneas obtendrás un falso verdadero, por lo que un píxel adicional lo arreglará y no creará ningún problema adicional

Voy a pegar un coffeescript para esto solo para ser un ejemplo, utiliza un par de enlaces que están ocultos por defecto, con clases read-more y read-less, eliminará los que el overflow no necesita y eliminará el cuerpo -las clases de desbordamiento

 jQuery -> $('.read-more').each -> if $(this).parent().find("h5").height() < 63 $(this).parent().removeClass("body-overflow-hidden").find(".read-less").remove() $(this).remove() else $(this).show() $('.read-more').click (event) -> event.preventDefault() $(this).parent().removeClass("body-overflow-hidden") $(this).hide() $(this).parent().find('.read-less').show() $('.read-less').click (event) -> event.preventDefault() $(this).parent().addClass("body-overflow-hidden") $(this).hide() $(this).parent().find('.read-more').show() 

Tengo una solución que funciona bien, pero en lugar de una elipsis usa un gradiente. Funciona cuando tienes texto dynamic, por lo que no sabes si será lo suficientemente largo como para necesitar una elipse. Las ventajas son que no tiene que hacer ningún cálculo de JavaScript y funciona para contenedores de ancho variable, incluidas las celdas de la tabla, y es un navegador cruzado. Utiliza un par de divs adicionales, pero es muy fácil de implementar.

Margen:

  
content goes here

CSS:

 .fade-container { /*two lines*/ overflow: hidden; position: relative; line-height: 18px; /* height must be a multiple of line-height for how many rows you want to show (height = line-height x rows) */ height: 36px; -ms-hyphens: auto; -webkit-hyphens: auto; hyphens: auto; word-wrap: break-word; } .fade { position: absolute; top: 50%;/* only cover the last line. If this wrapped to 3 lines it would be 33% or the height of one line */ right: 0; bottom: 0; width: 26px; background: linear-gradient(to right, rgba(255,255,255,0) 0%,rgba(255,255,255,1) 100%); } 

publicación de blog: http://salzerdesign.com/blog/?p=453

página de ejemplo: http://salzerdesign.com/test/fade.html

Código de ejemplo básico, aprender a codificar es fácil. Comprobar los comentarios CSS de estilo.

 table tr { display: flex; } table tr td { /* start */ display: inline-block; /* <- Prevent  in a display css */ text-overflow: ellipsis; white-space: nowrap; /* end */ padding: 10px; width: 150px; /* Space size limit */ border: 1px solid black; overflow: hidden; } 
 
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla egestas erat ut luctus posuere. Praesent et commodo eros. Vestibulum eu nisl vel dui ultrices ultricies vel in tellus. Praesent vitae tempus nulla. Donec vel porta velit. Fusce mattis enim ex. Mauris eu malesuada ante. Aenean id aliquet leo, nec ultricies tortor. Curabitur non mollis elit. Morbi euismod ante sit amet iaculis pharetra. Mauris id ultricies urna. Cras ut nisi dolor. Curabitur tellus erat, condimentum ac enim non, varius tempor nisi. Donec dapibus justo odio, sed consequat eros feugiat feugiat. Pellentesque mattis consequat ipsum sed sagittis. Pellentesque consectetur vestibulum odio, aliquet auctor ex elementum sed. Suspendisse porta massa nisl, quis molestie libero auctor varius. Ut erat nibh, fringilla sed ligula ut, iaculis interdum sapien. Ut dictum massa mi, sit amet interdum mi bibendum nec.
Sed viverra massa laoreet urna dictum, et fringilla dui molestie. Duis porta, ligula ut venenatis pretium, sapien tellus blandit felis, non lobortis orci erat sed justo. Vivamus hendrerit, quam at iaculis vehicula, nibh nisi fermentum augue, at sagittis nibh dui et erat. Nullam mollis nulla justo, nec tincidunt urna suscipit non. Donec malesuada dolor non dolor interdum, id ultrices neque egestas. Integer ac ante sed magna gravida dapibus sit amet eu diam. Etiam dignissim est sit amet libero dapibus, in consequat est aliquet. Vestibulum mollis, dui eu eleifend tincidunt, erat eros tempor nibh, non finibus quam ante nec felis. Fusce egestas, orci in volutpat imperdiet, risus velit convallis sapien, sodales lobortis risus lectus id leo. Nunc vel diam vel nunc congue finibus. Vestibulum turpis tortor, pharetra sed ipsum eu, tincidunt imperdiet lorem. Donec rutrum purus at tincidunt sagittis. Quisque nec hendrerit justo.

He estado buscando esto, pero luego me doy cuenta, maldita sea, ¡mi sitio web usa php! ¿Por qué no utilizar la función de recorte en la entrada de texto y jugar con la longitud máxima ….

Aquí hay una posible solución también para quienes usan php: http://ideone.com/PsTaI

  $max_length) { $offset = ($max_length - 3) - strlen($s); $s = substr($s, 0, strrpos($s, ' ', $offset)) . '...'; } echo $s; ?>