多行文本注视 php,多行文本进行截断的奇淫巧技
本篇文章給大家帶來的內容是關于多行文本進行截斷的奇淫巧技,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。
單行文字的截斷非常簡單,但是多行文字的截斷可謂是非常頭疼,剛學css時候就為了這個寫了很多亂七八糟的代碼,今天工作又遇到了這個需求...比較巧的是某公眾號今天正好也推送了一篇如何設置截斷的文章,心血來潮就自己將見到的各種方法總結下,也算加深記憶與理解。
各種奇淫巧技
先預設一個html結構,分別用不同的方法對其進行嘗試,html結構:
中國足球就像是一列疾馳而過的地鐵,當再一次與世界杯擦肩而過的時候,我們才會更清楚地意識到,這列地鐵的前方也許依舊是冬天,但是里皮的到來或許可以讓那個冬天不再像以往那樣的寒冷和漫長,因為至少他在用他的睿智和對足球的熱情點亮了我們前方的路,只愿這終將是一列開往春天的地下鐵。初始css代碼,主要設置了容器的寬度,行高和overflow:hidden:.wrap {
width: 300px;
height: 3.6em;
border: 1px solid #eee;
overflow: hidden;
font: 700 16px/1.2 "微軟雅黑";
}
下面的方法都是在樣式名wrap的基礎上添加各自的多重選擇器。
-webkit-line-camp實現
這個放在第一個說,因為這個可能是最簡單的方法了,代碼:.line-camp {
display: -webkit-box;
-webkit-line-clamp: 3;
-webkit-box-orient: vertical;
}
直接用-webkit-line-clamp控制行數,就可以達到目的,當文字超過三行的時候就會截斷加上省略號。但是看到這個-webkit-就會知道這個只針對webkit內核瀏覽器,火狐都是不支持的,這可是很嚴重的問題,目前也沒有很好的hack方法。并且注意這里文字我用了p包裹,加入用p等有默認內邊距或外邊距的元素包裹,這個樣式就會出很大的問題無法使用。因此這個屬性看起來美但是使用起來局限性太大了...不得不吐槽為啥不把這個屬性規范統一了,也就沒下面那么多事了。
浮動特性實現
這個方法我看到真得是被驚艷到了,網上有很多文章介紹了這個,搜了下找到了原文。這里就復述下。
從這個方法的思想源頭來分析,假設一個固定大小(寬300px)的容器內部有三個塊,一個左浮動(寬100px)高度撐滿,右邊兩個右浮動根據文字多少自適應撐開。
當藍色塊中的文字逐漸增多時候,橙色塊的位置也會發生變化,圖中容器高度正好是三倍的行高,因此當藍色塊文字少于或等于三行的時候,橙色塊一直在藍色塊的右下方移動:
當藍色塊文字大于三行的時候,橙色塊會移動到藍色塊右側,粉色塊下面:
由于浮動的特性,橙色塊的移動給了我們靈感,新增一個黃色塊相對于橙色塊定位:.realend {
position: absolute;
width: 100%;
top: -20px;
left: 200px;
background-color: yellow;
}
那么隨著藍色塊文字增多黃色塊移動的效果如下:
很驚喜的發現這樣做的話,當藍色塊文字溢出時候,黃色塊正好在右下角可以作為省略號的位置,而未溢出時候黃色塊是溢出容器的,正好符合要求。
但是這樣多一個標簽絕對定位明顯是很啰嗦的,我們采用相對定位就可以了,只保留黃色塊:.realend {
float: right;
width: 80px;
background-color: yellow;
position: relative;
left: 200px;
top: -20px;
}
效果一樣的:
整個思路已經有了,下面就輪到處理現在存在的問題了,紅色塊的寬度把藍色塊推到右邊100px的距離,顯然是不合理的,我們利用負margin處理藍色塊,將藍色塊設置為100%寬度,然后margin-left設置為-100px,這樣藍色塊就能充滿整個容器覆蓋了粉色塊,這時候黃色塊也設置自身寬度的負margin-left設置為-80px,然后用盒模型的原理再設置padding-right為粉色塊的寬度100px(設置margin-right也可以,都是利用盒模型讓黃色塊實際盒模型寬度為紫色塊的寬度),這里的負邊距的用法很巧妙,可以多理解下,然后再left百分百定位就可以了。.main {
float: right;
width: 100%;
margin-left: -100px;
background-color: #00ffff;
}
.realend {
float: right;
width: 80px;
background-color: yellow;
position: relative;
left: 100%;
top: -20px;
margin-left: -80px;
padding-right: 100px;
}
效果如下:
給容易加上overflow:hidden就達到效果了。
最后我們就根據上面的原理實現第二種文字截斷:.ellipsis:before {
content:"";
float: left;
width: 5px; height: 3.6em; }
.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: -1.2em; 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也有很大幫助,js方法其實很繁瑣效率也很低不到迫不得己還是不要使用。
總結
以上是生活随笔為你收集整理的多行文本注视 php,多行文本进行截断的奇淫巧技的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python 运行java jar包,从
- 下一篇: java substance下载,做出漂