2012-08-16 27 views
42

Quiero envolver un texto dentro de solo dos líneas dentro de div de ancho específico. Si el texto va más allá de la longitud de dos líneas, entonces quiero mostrar elipses. ¿Hay alguna manera de hacerlo usando CSS?Ajustar un texto dentro de solo dos líneas dentro de div

p. Ej.

Sample text showing wrapping 
of text in only two line... 

Gracias

Respuesta

75

limitar la producción de dos líneas de texto es posible con CSS, si se establece la line-height y height del elemento, y establecer overflow:hidden;:

#someDiv { 
    line-height: 1.5em; 
    height: 3em;  /* height is 2x line-height, so two lines will display */ 
    overflow: hidden; /* prevents extra lines from being visible */ 
} 

--- jsFiddle DEMO ---

Alternativamente, puede usar el CSS text-overflow y white-space apropiado lazos para agregar elipses, 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 ---

El logro de ambos múltiples líneas de texto y elipses parece ser el reino de JavaScript.

+8

sólo veo una línea que atraviesa por alguna razón:/ – SearchForKnowledge

+0

Es esta desactualizado? – rclai

+0

El segundo ejemplo no funciona en IE ... – Weggo

8

creo que la solución CSS sólo text-overflow: ellipsis se aplica a una solo 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?

+0

como mencioné, combinar elipses con varias líneas de texto no parece funcionar, al menos no para mí en Chrome. – jackwanders

+0

Esto funcionó en mi problema actual después de que agregué: 'display: block' y' min-height: 13px' y 'max-height: 26px' para establecer la altura para un' ' – Underverse

2

Ver http://jsfiddle.net/SWcCt/.

acaba de establecer un line-height la mitad de height:

line-height:20px; 
height:40px; 

Por supuesto, con el fin de hacer el trabajo text-overflow: ellipsis también necesita:

overflow:hidden; 
white-space: pre; 
+0

Esta solución no es flexible y requiere una línea manual romper en el texto de origen. Tenga en cuenta que http://jsfiddle.net/SWcCt/282/ cada cuadro solo contiene una línea de texto. La solución deseada se parecería a la 2da caja de http://jsfiddle.net/SWcCt/283/ excepto con puntos suspensivos al final de la 2da línea. –

+0

@JoshuaCoady Buen punto, pero 'text-overflow: ellipsis' solo funciona para cajas en línea que desbordan el cuadro de línea. Sin 'espacio en blanco: pre', simplemente irían al siguiente cuadro de línea. Y luego se necesita un salto de línea manual. No creo que haya una solución perfecta. – Oriol

11

El mejor que he visto, que es CSS solo y receptivo viene de Mobify Developer Blog - CSS Ellipsis: How to Manage Multi-Line Ellipsis in Pure CSS:

JS Fiddle Example

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 &ndash; never mind how long precisely &ndash; 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 &ndash; then, I account it high time to get to sea as soon as I can.</p> 
    </div> 
</div> 
+0

La mejor solución que he visto hasta ahora. Es posible que desee reducir la variable de altura (200px) en el violín, para el tamaño de mi pantalla, el texto no se desbordó inicialmente. –

6

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 original y la respuesta es here

+1

¡la mejor solución está aquí! –

2

probar algo lik e 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; 
} 
1

Típicamente un truncado de una línea es bastante simple

.truncate-text { 
    overflow: hidden; 
    text-overflow: ellipsis; 
    white-space: nowrap; 
} 

Dos truncado línea es un poco más complicado, pero se puede hacer con css este ejemplo es en Sass. Sólo

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

CSS solución 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>

Cuestiones relacionadas