2行のテキストオーバーフローの省略記号


117

CSSルールの組み合わせを使用して、オーバーフロー(親の境界から抜け出す)のタイミングでテキストを省略記号(...)で終了できることを知っています。

同じ効果を達成することはできますが(簡単に言ってもかまいません)、テキストを複数行で折り返すことはできますか?

こちらがデモです。

div {
  width: 300px; 
  height: 42px; 
  overflow: hidden; 
  text-overflow: ellipsis; 
  white-space: nowrap;
}

ご覧のように、テキストはdivの幅よりも広くなると省略記号で終わります。ただし、テキストを2行目に折り返すための十分なスペースがまだあります。これはwhite-space: nowrap、省略記号が機能するために必要なによって中断されます。

何か案は?

PS:JSソリューションはありません、可能な場合は純粋なCSS。


「空間あり」を決めるのは何ですか?フォントの高さを含むすべてがセットのピクセルですか?エンドユーザーがブラウザでフォントサイズを大きくするとどうなりますか?
Joel Etherton 2013


@JoelEthertonそれはブラウザーの判断次第だと思います。そうです。私の場合、すべてがピクセル単位です。
Tony Bogdanov

:これは良い解決策になることができ stackoverflow.com/questions/6222616/...
アイビー

これは本当に素敵な読み取りであるhackingui.com/front-end/...
anandharshan

回答:


31

私はあなたが見ているかどうかわからないんだけど、これを、しかしクリスCoyierの優れたCSS-Tricks.comがバックしながら、このAへのリンクを掲載し、それはあなたが求める正確に何を達成し、純粋なCSSのソリューションです。

(CodePenで表示するにはクリックしてください)

HTML:

<div class="ellipsis">
    <div>
        <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>

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-size: 100% 100%;/* 512x1 image,gradient for IE9. Transparent at 0% -> white at 50% -> white at 100%.*/
    background-image:url();
    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);
    }

もちろん、純粋なCSSソリューションであることは、かなり複雑なソリューションでもあることを意味しますが、クリーンでエレガントに機能します。これはJavascriptで実現する方がはるかに簡単(そしておそらくより分解可能)であるため、Javascriptは問題外だと思います。

追加のボーナスとして、プロセス全体のダウンロード可能なzipファイル(それとすべてを理解したい場合)だけでなく、SASSミックスインファイルもあり、簡単にプロセスに折りたたむことができます。

お役に立てれば!

http://www.mobify.com/blog/multiline-ellipsis-in-pure-css/


AndroidフォンでCodepenリンクをクリックしただけで、Firefoxで動作しました。どのプラットフォーム/ブラウザで動作していませんか?
dashard

uploady.com/#!/download/kAwBXv1CqXg/PU68wrP6QzGgydlS Chromeを使用していますが、プレビューに省略記号がありません。テキスト行を追加し続けると、何も起こりません。何行後に省略記号が表示されますか?
–coding_idiot

投稿したアップロードリンクでは、テキストはまだコンテナーからオーバーフローしていません。楕円が表示される前に、固定コンテナーを表示するにはテキストが多すぎる必要があります。効果を確認するには、テキストを追加し続けるだけです。
dashard 2015年

@MarcosPérezGude-私を驚かせません。>> "もちろん、純粋なCSSソリューションであることは、かなり複雑なソリューションでもあることを意味します..." <<
dashard

136

簡単なCSSプロパティは、トリックを行うことができます。以下は、3行の省略記号です。

display: -webkit-box;
-webkit-line-clamp: 3;
-webkit-box-orient: vertical;
overflow: hidden;
text-overflow: ellipsis;

15
これはFirefoxでは機能しません。クロム、サファリ、オペラのみ
anyavacy

1
よるcaniuse、それは「そのまま他のブラウザがプロパティをサポートすることはほとんどありません」と述べています。だから頭を上げます。
Matan Bobi、

スムーズな男..非常に役立つ
Valentino Pereira

4
Firefox 8でもgr8を使用
Nisharg Shah

4
今、素晴らしいサポートがあるようです:caniuse.com/#search=line-clamp
Joao

51

この純粋なCSSバージョンを見てくださいhttp : //codepen.io/martinwolf/pen/qlFdp

display: -webkit-box;
max-width: 400px;
height: 109.2px;
-webkit-line-clamp: 3;
-webkit-box-orient: vertical;
overflow: hidden;
text-overflow: ellipsis;
line-height: 1.625;

7
それは本当にクールですが、残念ながらWebkitだけです。問題に関する興味深い記事は次のとおり
Tony Bogdanov

なぜあなたは2宣言しないtext-overflowdisplayルールを?
j08691 2017

大きなWoooW。ラインクランプの前に見たことのないアイブ
マイク・アロン

1
ちなみに、これは最近のFirefoxでも問題なく動作します。素晴らしい解決策!
Athoxx

1つの質問のみ、1行または2行のテキストがある場合、中央揃えにしたいのですが、どうすれば表示フレックスを追加した場合、省略記号が失われます。これは、display:-webkit boxが設定されている場合にのみ機能するようです
PirateApp

10

以下のCssがトリックを実行します。

2行目の後、テキストには...が含まれます。

line-height: 1em;
max-height: 2em;
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;

これはうまくいきましたが、追加しなければなりませんでしたoverflow:hidden
timhysniu

2

私のソリューションはamcdnlの1つを再利用していますが、私のフォールバックは、テキストコンテナーの高さの使用で構成されています。

.my-caption h4 {
    display: -webkit-box;
    margin: 0 auto;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;

    height: 40px;/* Fallback for non-webkit */
}

-webkit-line-clampIE11、Edge、またはFirefoxでは機能しません。
Gaʀʀʏ

@ギャリー、あなたは正しい、あなたはJSの修正が必要だったかもしれませんが、今はそれがうまくいきます。caniuse.com/#search=webkit-line-clamp
VincentPerrin.com

2

上記が機能しない場合はこれを使用してください

 display: block;
 display: -webkit-box;
 max-width: 100%;
 margin: 0 auto;
 -webkit-line-clamp: 2;
 /* autoprefixer: off */
 -webkit-box-orient: vertical;
 /* autoprefixer: on */
 overflow: hidden;
 text-overflow: ellipsis;

1

stackoveflowで見た回答に基づいて、このLESSミックスインを作成しました(このリンクを使用してCSSコードを生成します):

.max-lines(@lines: 3; @line-height: 1.2) {
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: @lines;
  line-height: @line-height;
  max-height: @line-height * @lines;
}

使用法

.example-1 {
    .max-lines();
}

.example-2 {
    .max-lines(3);
}

.example-3 {
    .max-lines(3, 1.5);
}

1

2つのクラスを組み合わせると、よりエレガントに見えます。two-lines1行だけが参照する必要がある場合は、クラスをドロップできます。

.ellipse {
          white-space: nowrap;
          display:inline-block;
          overflow: hidden;
          text-overflow: ellipsis;
       }
      .two-lines {
          -webkit-line-clamp: 2;
          display: -webkit-box;
          -webkit-box-orient: vertical;
          white-space: normal;
      }
      .width{
          width:100px;
          border:1px solid hotpink;
      }
        <span class='width ellipse'>
          some texts some texts some texts some texts some texts some texts some texts
       </span>

       <span class='width ellipse two-lines'>
          some texts some texts some texts some texts some texts some texts some texts
       </span>


1

数行に制限すると、ほとんどすべてのブラウザで機能しますが、省略記号(3ドット)はFirefoxおよびIEでは表示されません。デモ-http://jsfiddle.net/ahzo4b91/1/

div {
width: 300px;
height: 2.8em;
line-height: 1.4em;
display: flex;
-webkit-line-clamp: 2;
display: -webkit-box;
-webkit-box-orient: vertical;
overflow: hidden; 
}

0
          text-overflow: ellipsis;
          overflow: hidden;
          text-overflow: ellipsis;
          display: -webkit-box;
          line-height: 36px;
          max-height: 18px;
          -webkit-line-clamp: 2;
          -webkit-box-orient: vertical;

線クランプと線高さの両方の組み合わせを見つけました:D


0

私の角度付きアプリでは、2行目のテキストのオーバーフローで省略記号を実現するために次のスタイルが機能しました。

 <div style="height:45px; overflow: hidden; position: relative;">
     <span class=" block h6 font-semibold clear" style="overflow: hidden;
        text-overflow: ellipsis;
        display: -webkit-box; 
        line-height: 20px; /* fallback */
        max-height: 40px; /* fallback */
        -webkit-line-clamp: 2; /* number of lines to show */
        -webkit-box-orient: vertical;">
        {{ event?.name}} </span>
 </div>

それが誰かを助けることを願っています。


0

scssで作業する場合!autoprefixerは、コメントをpostcssで保持できるようにコメントの先頭に追加する必要があります。

その問題に直面したので、ここに投稿しました

line-height: 1em;
max-height: 2em;
display: -webkit-box;
/*! autoprefixer: off */
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;

参照


0

省略記号、純粋なCSSの代わりに溶解効果を使用でき、よりプロフェッショナルに見えます。

    <div style="width: 293px; height:48px; overflow: hidden; ">
        More than two line of text goes here-More than two line of text goes here
    </div>
    <div style="position: relative; top: -24px; width: 293px; height:24px; 
             background: linear-gradient(90deg, rgba(255,0,0,0) 40%, rgba(255,255,255,1) 99%);">
    </div>

ここでは、背景色を白と想定しています。


-1

これは完全なハックですが、動作します:

http://jsfiddle.net/2wPNg/

div {
    width: 30%;
    float: left;
    margin-right: 2%;
    height: 94px;
    overflow: hidden;
    position: relative;
}

div:after {
     display: block;
      content: '...';
      width: 1em;
  height: 1.5em;
  background: #fff;
  position: absolute;
  bottom: -6px;
  right: 0;
    }

それは問題を持っています....それはぎこちなく手紙を切り取るかもしれません、そしてそれはおそらく応答サイトでいくつかの奇妙な結果をもたらすでしょう。


5
コンテンツが小さい場合、最後に「...」が追加されるため、これは正しい解決策にはなりません。フィドル:jsfiddle.net/2wPNg
Sachin

-1

jQueryを使用して省略記号を管理する簡単なスクリプトを次に示します。要素の実際の高さを検査し、非表示の元のノードと切り捨てられたノードを作成します。ユーザーがクリックすると、2つのバージョンが切り替わります。

大きな利点の1つは、予想どおり、「省略」が最後の言葉に近いことです。

純粋なCSSソリューションを使用する場合、3つのドットは最後の単語から離れて表示されます。

function manageShortMessages() {

        $('.myLongVerticalText').each(function () {
            if ($(this)[0].scrollHeight > $(this)[0].clientHeight)
                $(this).addClass('ellipsis short');
        });

        $('.myLongVerticalText.ellipsis').each(function () {
            var original = $(this).clone().addClass('original notruncation').removeClass('short').hide();
            $(this).after(original);

            //debugger;
            var shortText = '';
            shortText = $(this).html().trim().substring(0, 60) + '...';
            $(this).html(shortText);
        });
        
        $('.myLongVerticalText.ellipsis').click(function () {
            $(this).hide();

            if ($(this).hasClass('original'))
            {
                $(this).parent().find('.short').show();
            }
            else
            {
                $(this).parent().find('.original').show();
            }
        });
    }
	
  manageShortMessages();
div {
 border:1px solid red;
 margin:10px;
}

div.myLongVerticalText {
  height:30px;
  width:450px;
}

div.myLongVerticalText.ellipsis {
 cursor:pointer;
}

div.myLongVerticalText.original {
  display:inline-block;
  height:inherit;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<body>
<div class="myLongVerticalText">
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse sit amet quam hendrerit, sagittis augue vel, placerat erat. Aliquam varius porta posuere. Aliquam erat volutpat. Phasellus ullamcorper malesuada bibendum. Etiam fringilla, massa vitae pulvinar vehicula, augue orci mollis lorem, laoreet viverra massa eros id est. Phasellus suscipit pulvinar consectetur. Proin dignissim egestas erat at feugiat. Aenean eu consectetur erat. Nullam condimentum turpis eu tristique malesuada.

Aenean sagittis ex sagittis ullamcorper auctor. Sed varius commodo dui, nec consectetur ante condimentum et. Donec nec blandit mi, vitae blandit elit. Phasellus efficitur ornare est facilisis commodo. Donec convallis nunc sed mauris vehicula, non faucibus neque vehicula. Donec scelerisque luctus dui eu commodo. Integer eu quam sit amet dui tincidunt pharetra eu ac quam. Quisque tempus pellentesque hendrerit. Sed orci quam, posuere eu feugiat at, congue sed felis. In ut lectus gravida, volutpat urna vitae, cursus justo. Nam suscipit est ac accumsan consectetur. Donec rhoncus placerat metus, ut elementum massa facilisis eget. Donec at arcu ac magna viverra tincidunt.
</div>


<div class="myLongVerticalText">
One Line Lorem ipsum dolor sit amet.  
</div>
</body>


このソリューションに反対票を投じた場合は、その理由をここで説明してください。感謝します。
Matteo Conta 2017

1
OPがCSSソリューションを要求し、jQueryを提供しましたか?
dashard 2017

javascriptが存在しないことが大きな要件であるとは思いませんでした。私の場合、純粋なCSSソリューションではレンダリングの問題が発生し、jQueryソリューションでは最終的なレンダリングと省略記号の位置をより詳細に制御できました。
Matteo Conta 2017

全く同感であります。私の回答では、これはJSを使用すると非常に簡単に実現できることに気付きました。
dashard

-3

ターゲットが何かはわかりませんが、テキストを2行目に表示しますか?

ここにあなたのjsFiddleがあります:http ://jsfiddle.net/8kvWX/4/ 以下を削除しました:

     white-space:nowrap;  

これがあなたが探しているものかどうかわかりません。

よろしく、

ミー


1
彼は2行目の終わりに省略記号を望んでいます。これはJavaScriptなしではそれほど簡単ではありません...
Marc Audet

@MarcAudet正確に:)
トニーボグダノフ

そう、別の人が2行目に行を追加するように要求しているのを見つけたので、彼のCSSはあなたのCSSとほとんど同じでしたが、クラスは代わりにulタグを指しています。とにかく、ごめん、トニー。私はそれをもう一度見て、成功したら私の答えを更新します。
ミー

最高の解決策は@Itay Galの解決策だと思います。私が見た限りでは、それは機能しています。
ミー
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.