要素内に収まらない自動的に文字列を省略する
サイトを製作している時、文字数が長すぎてレイアウトが崩れるといった経験はないでしょうか?
文字数を調整できるのであれば、それでよいかもしれませんが、文字数の調整が困難な場合もあるかと思います。
今回は、表示領域からはみ出してしまった文字列を自動的に省略する方法をご紹介していきます。
今回の方法はCSSのみで対応可能です。
長い文字列は【text-overflow】を使って省略する
text-overflowを使うことで、文字列が表示領域からはみ出してしまった場合、はみ出した文字列を省略し、末尾に三点リーダー(…)を表示することが出来ます。
<div class="test">
<p>ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。</p>
</div>
上記のようなHTMLの場合、以下の様にCSSを定義してやれば、要素からはみ出した文字列を省略することができます。
.test {
width: 100%;
}
.test p {
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
以下の様に文字列の末尾が省略され、三点リーダー(…)が自動的に表示されます。
ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。
【text-overflow】を使って文字列を省略する方法は、現在、ほとんどのブラウザで利用することができると言えるでしょう。
複数行表示させてから省略させたい場合
先ほどご紹介した方法は、文字列を1行表示でしか省略することができません。
場合によっては、何行か表示させてから省略したいことも考えられます。
そんなときは、【-webkit-line-clamp】を使い事で対応することができます。
<div class="test">
<p>ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。</p>
</div>
上記のようなHTMLの場合、以下の様にCSSを定義してやれば、指定した行数を表示した後、要素からはみ出す文字列を省略することができます。
.test {
width: 100%;
}
.test p {
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2;
overflow: hidden;
}
以下の様に文字列の末尾が省略され、三点リーダー(…)が自動的に表示されます。
ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。ここに文字列を記載します。
上記では、2行表示してそれ以降の文字列を省略するようにしてみました。
CSSの中にある【-webkit-line-clamp: 2;】の【2】の部分が行数を指定している値です。
3行表示したいのであれば、この値を【3】に変更してやります。
ただ、この方法は一部のブラウザでしかサポートされていません。
IEなどでは正常に省略されて表示されませんので、注意が必要です。
まとめ
要素に収まらない長い文字列を自動的に省略する方法をご紹介いたしました。
今回の方法はCSSのみで対応可能で、jsなどの力は借りません。
簡単でよいですね!
・1行表示で収まらない文字列を省略するのなら【text-overflow】
・何行か表示させてから文字列を省略させるなら【-webkit-line-clamp】
必要に応じて使い分けてください。
コメントを残す