自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

如何用CSS實現(xiàn)多行文本的省略號顯示

開發(fā) 前端
本文將要介紹的方法是采用CSS規(guī)范中的屬性,并結(jié)合特殊的實現(xiàn)技巧完成的。這意味著在實現(xiàn)CSS2.1規(guī)范的瀏覽器中都是可以兼容的,不將僅僅是純粹的移動端領(lǐng)域,在傳統(tǒng)的PC瀏覽器(你們懂得我指的是哪些瀏覽器)中仍是可行的。

本文翻譯自CSS Ellipsis: How to Manage Multi-Line Ellipsis in Pure CSS,文中某些部分有些許改動,并添加譯者的一些感想,請各位讀者諒解。

合理的截斷多行文本是件不容易的事情,我們通常采用幾種方法解決:

  • overflow: hidden直接隱藏多余的文本
  • text-overflow: ellipsis只適用于單行文本的處理
  • 各種比較脆弱的javascript實現(xiàn)。之所以說這種實現(xiàn)比較脆弱是由于需要文本長度的變化時刻得到回流(relayout)后的布局信息,如寬度

英文原文寫作時間是2012.9.18號,比較有意義的一天。不過作者忽略了WebKit提供的一個擴展屬性-webkit-line-clamp,它并不是CSS規(guī)范中的屬性。利用該屬性實現(xiàn)多行文本的省略號顯示需要配合其他三個屬性:display: -webkit-box、-webkit-box-orient、text-overflow: ellipsis;。其中,-webkit-line-clamp設(shè)置塊元素包含的文本行數(shù);display: -webkit-box設(shè)置塊元素的布局為伸縮布局;-webkit-box-orient設(shè)置伸縮項的布局方向;text-overflow: ellipsis;則表示超出盒子的部分使用省略號表示。

不過本文將要介紹的方法是采用CSS規(guī)范中的屬性,并結(jié)合特殊的實現(xiàn)技巧完成的。這意味著在實現(xiàn)CSS2.1規(guī)范的瀏覽器中都是可以兼容的,不將僅僅是純粹的移動端領(lǐng)域,在傳統(tǒng)的PC瀏覽器(你們懂得我指的是哪些瀏覽器)中仍是可行的。好吧,讓我們一起見識下。

CSS實現(xiàn)多行文本溢出的省略號顯示

我們把實現(xiàn)的細(xì)節(jié)劃分為7個步驟,在這個實現(xiàn)過程中最簡單的就是截斷文本,而最難的部分則是讓一個元素處在其父包含塊溢出時的右下方,并且當(dāng)父元素未溢出時該元素消失不可見。為了去難避易,我們先從比較簡單的地方開始–當(dāng)父包含框比較小時,將子元素布局到父包含框的右下角。

1st 引子 

 

 

  

 

 

 

其實這個實現(xiàn)完全利用了元素浮動的基本規(guī)則。在這里不詳細(xì)講解CSS2.1規(guī)范中的幾種情形,不明白的讀者自行查閱。這段代碼實現(xiàn)很簡單,就是三個子元素和包含塊的高度及浮動設(shè)置:

  1. <div class="wrap"
  2.  
  3.   <div class="prop">1.prop<br>float:left</div> 
  4.  
  5.   <div class="main">2.main<br>float:right<br>Fairly short text</div> 
  6.  
  7.   <div class="end">3.end<br>float:right</div> 
  8.  
  9. </div> 
  10.  
  11.   
  12.  
  13. .wrap { 
  14.  
  15.   width: 400px; height: 200px; 
  16.  
  17.     margin: 20px 20px 50px; 
  18.  
  19.     border: 5px solid #AAA; 
  20.  
  21.     line-height: 25px; 
  22.  
  23.  
  24.   
  25.  
  26. .prop { 
  27.  
  28.     floatleft
  29.  
  30.     width: 100px; height: 200px; 
  31.  
  32.     background: #FAF; } 
  33.  
  34. .main { 
  35.  
  36.     floatright
  37.  
  38.     width: 300px; 
  39.  
  40.     background: #AFF; } 
  41.  
  42. .end { 
  43.  
  44.     floatright
  45.  
  46.     width: 100px; 
  47.  
  48.     background: #FFA; }  

2nd 模擬場景

我們通過創(chuàng)建一個子元素來替代將要顯示的省略號,當(dāng)文本溢出的情形下該元素顯示在正確的位置上。在接下來的實現(xiàn)中,我們創(chuàng)建了一個realend元素,并利用上一節(jié)end元素浮動后的位置來實現(xiàn)realend元素的定位。

  1. <div class="wrap"
  2.  
  3.   <div class="prop"
  4.  
  5.    1.prop<br> 
  6.  
  7.    float:right</div> 
  8.  
  9.   <div class="main"
  10.  
  11.    2.main<br> 
  12.  
  13.    float:left<br> 
  14.  
  15.    Fairly short text</div> 
  16.  
  17.   <div class="end"
  18.  
  19.    <div class="realend"
  20.  
  21.      4.realend<br> 
  22.  
  23.      position:absolute</div> 
  24.  
  25.   3.end<br>float:right 
  26.  
  27.   </div> 
  28.  
  29. </div> 
  30.  
  31.   
  32.  
  33. .end { 
  34.  
  35.     floatright; position: relative
  36.  
  37.     width: 100px; 
  38.  
  39.     background: #FFA; } 
  40.  
  41. .realend { 
  42.  
  43.     position: absolute
  44.  
  45.     width: 100%; 
  46.  
  47.     top: -50px; 
  48.  
  49.     left: 300px; 
  50.  
  51.     background: #FAA; font-size: 13px; }  

這一步中,我們主要關(guān)心的是realend元素的定位,基于浮動后的end元素設(shè)置偏移量,當(dāng)end元素浮動到***節(jié)第二章圖的位置時(即在prop元素的下方),此時realend元素正好處在end元素的上方50px,右側(cè)300px-100px=200px處,而該位置正是父包含框wrap元素的右下角,此時正是我們期待的結(jié)果: 

 

 

 

若父元素并沒有溢出,那么realend元素會出現(xiàn)在其右側(cè) 

 

 

這種情況解決很簡單,請看下文之第七節(jié),此處僅作實例說明。

3rd 優(yōu)化定位模型

在第二節(jié)中,我們針對end元素設(shè)置了相對定位,對realend元素設(shè)置絕對定位。但是我們可以采用更為簡單的代碼來實現(xiàn),即只使用相對定位。熟悉定位模型的同學(xué)應(yīng)該知道,相對定位的元素仍然占據(jù)文本流,同時仍可針對元素設(shè)置偏移。這樣,就可以去掉end元素,僅針對realend元素設(shè)置相對定位。

  1. <div class="wrap"
  2.  
  3.   <div class="prop">1.prop<br>float:right</div> 
  4.  
  5.   <div class="main">2.main<br>float:left<br>Fairly short text</div> 
  6.  
  7.   <div class="realend"
  8.  
  9.   3.realend<br>position:relative</div> 
  10.  
  11. </div> 
  12.  
  13.   
  14.  
  15. .realend { 
  16.  
  17.     floatright
  18.  
  19.         position: relative
  20.  
  21.     width: 100px; 
  22.  
  23.     top: -50px; left: 300px; 
  24.  
  25.     background: #FAA; font-size: 14px; }  

其他的屬性并不改變,效果一樣。

4th 削窄prop元素

目前,最左側(cè)的prop元素的作用在于讓realend元素在文本溢出時處在其正下方,在前幾節(jié)的示例代碼中為了直觀的演示,設(shè)置prop元素的寬度為100px,那么現(xiàn)在為了更好的模擬實際的效果,我們縮小逐漸縮小prop元素的寬度。

  1. <div class="wrap"
  2.  
  3.   <div class="prop">1.prop<br>float:right</div> 
  4.  
  5.   <div class="main">2.main<br>float:left<br>Fairly short text</div> 
  6.  
  7.   <div class="realend"
  8.  
  9.   3.realend<br>position:relative</div> 
  10.  
  11. </div> 
  12.  
  13.   
  14.  
  15.   
  16.  
  17. .prop { 
  18.  
  19.   floatleft
  20.  
  21.   width: 5px; 
  22.  
  23.   height: 200px; 
  24.  
  25.   background: #F0F; } 
  26.  
  27. .main { 
  28.  
  29.     floatright
  30.  
  31.     width: 300px; 
  32.  
  33.     margin-left: -5px; 
  34.  
  35.     background: #AFF; } 
  36.  
  37. .realend { 
  38.  
  39.     floatright
  40.  
  41.         position: relative
  42.  
  43.     top: -50px; 
  44.  
  45.         left: 300px; 
  46.  
  47.     width: 100px; 
  48.  
  49.         margin-left: -100px; 
  50.  
  51.     padding-right: 5px; 
  52.  
  53.     background: #FAA; font-size: 14px; }  

針對prop元素,縮小寬度為5px,其余屬性不變;

針對main元素,設(shè)置margin-left:5px,讓main元素左移5px,這樣main元素在寬度上就完全占滿了父元素;

對于realend元素,top、left和width的值不變。而設(shè)置margin-left: -100px、padding-right: 5px則是為了讓realend元素的盒模型的最終寬度計算為5px。

  1. BoxWidth = ChildMarginLeft + ChildBorderLeftWidth + ChildPaddingLeft + ChildWidth + ChildPaddingLeft + ChildBorderRightWidth + ChildMarginRightWidth; 

具體可參考我之前的文章負(fù)margin的原理以及應(yīng)用一文。

由于CSS規(guī)范規(guī)定padding的值不可以為負(fù)數(shù),因此只有設(shè)置margind-left為負(fù)值,且等于其寬度。這樣做的最終目的就是保證realend元素處在prop元素的下方,保證在文本溢出的情況下定位準(zhǔn)確性: 

 

 

 

5th 繼續(xù)優(yōu)化:流式布局+偽元素

目前,realend元素的相關(guān)屬性仍采用px度量,為了更好的擴展性,可以改用%替代。

同時,prop元素和realend元素可以采用偽元素來實現(xiàn),減少額外標(biāo)簽的使用。

  1. <div class="ellipsis"
  2.  
  3.   <div>2.main<br>float:left<br>Fairly short text 
  4.  
  5.   </div> 
  6.  
  7. </div> 
  8.  
  9.   
  10.  
  11. /*相當(dāng)于之前的prop元素*/ 
  12.  
  13. .ellipsis:before { 
  14.  
  15.     content: ""
  16.  
  17.     floatleft
  18.  
  19.     width: 5px; height: 200px; 
  20.  
  21.     background: #F0F; } 
  22.  
  23. /*相當(dāng)于之前的main元素*/ 
  24.  
  25. .ellipsis > *:first-child { 
  26.  
  27.     floatright
  28.  
  29.     width: 100%; 
  30.  
  31.     margin-left: -5px; 
  32.  
  33.     background: #AFF; } 
  34.  
  35. /*相當(dāng)于之前的realend元素*/ 
  36.  
  37. .ellipsis:after { 
  38.  
  39.     content: "realend"
  40.  
  41.     floatright; position: relative
  42.  
  43.     top: -25px; left: 100%; 
  44.  
  45.     width: 100px; margin-left: -100px; 
  46.  
  47.     padding-right: 5px; 
  48.  
  49.     background: #FAA; font-size: 14px; }  

效果圖和上節(jié)一樣。

6th 隱藏

之前的實現(xiàn)中在文本未溢出的情況下,realend元素會出現(xiàn)在父元素的右側(cè),正如。 

 

 

 

解決此問題很簡單,急需要設(shè)置:

  1. .ellipsis{ 
  2.  
  3.     overflow:hidden; 
  4.  
  5.  

即可解決問題。

7th 大功告成

現(xiàn)在我們離完結(jié)就差一步了,即去掉各元素的背景色,并且用“…”替換文本。***為了優(yōu)化體驗,采用漸變來隱藏“…”覆蓋的文本,并設(shè)置了一些兼容性的屬性。

到了此處,相信現(xiàn)在關(guān)心的只是CSS的代碼了:

  1. .ellipsis { 
  2.  
  3.   overflow: hidden; 
  4.  
  5.   height: 200px; 
  6.  
  7.     line-height: 25px; 
  8.  
  9.     margin: 20px; 
  10.  
  11.     border: 5px solid #AAA; } 
  12.  
  13.   
  14.  
  15. .ellipsis:before { 
  16.  
  17.     content:""
  18.  
  19.     floatleft
  20.  
  21.     width: 5px; height: 200px; } 
  22.  
  23.   
  24.  
  25. .ellipsis > *:first-child { 
  26.  
  27.     floatright
  28.  
  29.     width: 100%; 
  30.  
  31.     margin-left: -5px; }         
  32.  
  33.   
  34.  
  35. .ellipsis:after { 
  36.  
  37.     content: "\02026";   
  38.  
  39.   
  40.  
  41.     box-sizing: content-box; 
  42.  
  43.     -webkit-box-sizing: content-box; 
  44.  
  45.     -moz-box-sizing: content-box; 
  46.  
  47.   
  48.  
  49.     floatright; position: relative
  50.  
  51.     top: -25px; left: 100%; 
  52.  
  53.     width: 3em; margin-left: -3em; 
  54.  
  55.     padding-right: 5px; 
  56.  
  57.      
  58.  
  59.     text-align: right
  60.  
  61.   
  62.  
  63.    
  64.  
  65.         background-size: 100% 100%; 
  66.  
  67.   /* 512x1 image, gradient for IE9. Transparent at 0% -> white at 50% -> white at 100%.*/ 
  68.  
  69. background-image: url(); 
  70.  
  71.    
  72.  
  73.     background: -webkit-gradient(linear, left topright top
  74.  
  75.         from(rgba(255, 255, 255, 0)), to(white), color-stop(50%, white)); 
  76.  
  77.     background: -moz-linear-gradient(to right, rgba(255, 255, 255, 0), white 50%, white);           
  78.  
  79.     background: -o-linear-gradient(to right, rgba(255, 255, 255, 0), white 50%, white); 
  80.  
  81.     background: -ms-linear-gradient(to right, rgba(255, 255, 255, 0), white 50%, white); 
  82.  
  83.     background: linear-gradient(to right, rgba(255, 255, 255, 0), white 50%, white); 
  84.  

 總結(jié)之兼容性

從上文的實現(xiàn)細(xì)節(jié)來看,我們利用的技巧完全是CSS規(guī)范中的浮動+定位+盒模型寬度計算,唯一存在兼容性問題的在于無關(guān)痛癢的漸變實現(xiàn),因此可以在大多數(shù)瀏覽器下進行嘗試。 

責(zé)任編輯:龐桂玉 來源: 前端大全
相關(guān)推薦

2021-07-27 07:31:16

CSS 元素切換

2023-12-18 09:15:58

CSS前端容器查詢

2023-07-28 10:21:46

CSS前端

2016-11-16 15:05:42

情感分析

2022-08-02 06:39:06

多行文本CSS

2023-03-27 09:25:21

CSS自定義彩色字體

2023-07-05 16:07:02

JavaScriptWeb 應(yīng)用程序

2023-03-13 09:20:24

??Safari??省略號CSS

2018-12-10 15:18:43

蘋果手機符號

2010-09-09 10:23:23

DIVCSS垂直居中

2022-10-24 17:57:06

CSS容器查詢

2021-08-30 07:57:26

OpenAttack文本對抗攻擊

2021-09-13 06:03:42

CSS 技巧搜索引擎

2020-11-06 17:42:02

Python開發(fā)工具

2017-05-02 13:38:51

CSS繪制形狀

2009-09-08 15:12:07

C# ListBox

2010-08-26 13:32:05

CSSmargin參數(shù)

2010-08-24 14:47:48

CSS居中

2022-05-03 17:04:08

CSS前端

2021-01-11 10:10:23

開發(fā)文本溢出開發(fā)技術(shù)
點贊
收藏

51CTO技術(shù)棧公眾號