成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

CSS 如何實現(xiàn)多行文本展開收起效果

開發(fā) 前端
如果包含塊的高度顯式指定,則設(shè)置該元素為絕對定位:包含塊的高度是動態(tài)的,沒辦法顯式指定,所以此方法也不可用。

[[413428]]

本文轉(zhuǎn)載自微信公眾號「三分鐘學(xué)前端」,作者sisterAn 。轉(zhuǎn)載本文請聯(lián)系三分鐘學(xué)前端公眾號。

最終實現(xiàn)效果:

本文主要實現(xiàn)難點:

  • 如何實現(xiàn) 展開 和 收起 切換按鈕的文字環(huán)繞效果
  • 如何實現(xiàn)多行文本溢出省略效果
  • 如何實現(xiàn) 展開 和 收起 的狀態(tài)or文字切換

初始 html:

  1. <div class="text"
  2.   <label class="btn">展開</label> 
  3.   <span> 
  4.     但聽得蹄聲如雷,十余乘馬疾風(fēng)般卷上山來。馬上乘客一色都是玄色薄氈大氅, 
  5.     里面玄色布衣,但見人似虎,馬如龍,人既矯捷,馬亦雄駿,每一匹馬都是高頭 
  6.     長腿,通體黑毛,奔到近處,群雄眼前一亮,金光閃閃,卻見每匹馬的蹄鐵竟然 
  7.     是黃金打就。來者一共是一十九騎,人數(shù)雖不甚多,氣勢之壯,卻似有如千軍萬 
  8.     馬一般,前面一十八騎奔到近處,拉馬向兩旁一分,最后一騎從中馳出</span> 
  9. </div> 
  10. <style> 
  11.   .text { 
  12.     width: 475px; 
  13.     border: aqua solid 1px; 
  14.     color: #333; 
  15.     font-size: 14px; 
  16.   } 
  17.   .btn { 
  18.     color: dodgerblue; 
  19.     cursor: pointer; 
  20.   } 
  21. </style> 

 

 

控制按鈕文字環(huán)繞效果

一般展開、收起按鈕都在文字的右下腳:

  • 局右:float: right
  • 局下:margin-top

但 margin 雖然可以將按鈕局下,但它無法實現(xiàn)文字環(huán)繞效果,所以我們這里利用偽元素實現(xiàn):

  • 局右:float: right
  • 局下:.text::before

局右

  1. .text::before{ 
  2.     content: ''
  3.     floatright

局下

  1. .text::before{ 
  2.     content: ''
  3.     floatright
  4.     width: 0; 
  5.     height: calc(100% - 20px); 

我們發(fā)現(xiàn)出現(xiàn)了高度塌陷( calc(100% - 20px) 無效)的問題:

由于包含塊的高度沒有顯式指定,并且該元素不是絕對定位,則計算值偽 auto,auto * 100/100 = NaN

— CSS 世界

此時解決辦法有:

  • 設(shè)置顯式的高度值:這里高度是動態(tài)的,沒辦法顯式指定,所以此方法不可用?
  • 如果包含塊的高度顯式指定,則設(shè)置該元素為絕對定位:包含塊的高度是動態(tài)的,沒辦法顯式指定,所以此方法也不可用?
  • 在元素外邊包一層具有包裹性又具有定位特性的標(biāo)簽:?

這里包一層 flex 布局。因為在 flex 布局的子項中,可以通過百分比來計算變化高度,因此,這里需要給 .text 包裹一層,然后設(shè)置 display: flex

  1. <div class="content"
  2.  <div class="text"
  3.    <label class="btn" for="exp">展開</label> 
  4.    <span> 
  5.      但聽得蹄聲如雷,十余乘馬疾風(fēng)般卷上山來。馬上乘客一色都是玄色薄氈大氅, 
  6.      里面玄色布衣,但見人似虎,馬如龍,人既矯捷,馬亦雄駿,每一匹馬都是高頭 
  7.      長腿,通體黑毛,奔到近處,群雄眼前一亮,金光閃閃,卻見每匹馬的蹄鐵竟然 
  8.      是黃金打就。來者一共是一十九騎,人數(shù)雖不甚多,氣勢之壯,卻似有如千軍萬 
  9.      馬一般,前面一十八騎奔到近處,拉馬向兩旁一分,最后一騎從中馳出</span> 
  10.  </div> 
  11. </div> 
  1. <style> 
  2.  .content { 
  3.    display: flex; 
  4.  } 
  5.  .text::before{ 
  6.    content: ''
  7.    floatright
  8.    height: 100%; 
  9.    margin-bottom: -20px; 
  10.  } 
  11.  .btn { 
  12.    floatright
  13.    clear: both; 
  14.    margin-right: 8px; 
  15.  } 
  16. </style> 

 

 

 

 

 

多行文本溢出省略效果

我們在 CSS 實現(xiàn)文本的單行和多行溢出省略效果 介紹過:

多行文本(css)

  1. .text { 
  2.   display: -webkit-box; 
  3.   overflow: hidden; 
  4.   -webkit-line-clamp: 3; 
  5.   -webkit-box-orient: vertical; 
  • -webkit-line-clamp: 3(用來限制在一個塊元素顯示的文本的行數(shù), 2 表示最多顯示 2 行。為了實現(xiàn)該效果,它需要組合其他的WebKit屬性)
  • display: -webkit-box(和 1 結(jié)合使用,將對象作為彈性伸縮盒子模型顯示 )
  • -webkit-box-orient: vertical(和 1 結(jié)合使用 ,設(shè)置或檢索伸縮盒對象的子元素的排列方式 )
  • overflow: hidden(文本溢出限定的寬度就隱藏內(nèi)容)
  • text-overflow: ellipsis(多行文本的情況下,用省略號“…”隱藏溢出范圍的文本)

如何實現(xiàn) 展開 和 收起 的狀態(tài)切換

使用 input type="checkbox" 控制展開與收起效果

  1. <input type="checkbox" id="exp" /> 
  2.  
  3. <style> 
  4.   #exp { 
  5.     visibility: hidden; 
  6.   } 
  7.   #exp:checked+.text{ 
  8.     -webkit-line-clamp: 999; /*設(shè)置一個足夠大的行數(shù)就可以了*/ 
  9.   } 
  10. </style> 

但文字展開后控制按鈕依然顯示 展開 ,應(yīng)該顯示 收起 才對

這里使用偽類生成技術(shù),具體做法就是去除或者隱藏按鈕里面的文字,采用偽元素生成

  1. <label class="btn" for="exp"></label> 
  2. <style> 
  3.   .btn::after
  4.     content:'展開' 
  5.   } 
  6.   #exp:checked+.text .btn::after
  7.     content:'收起' 
  8.   } 
  9. </style> 

最終,大功告成:

 

責(zé)任編輯:武曉燕 來源: 三分鐘學(xué)前端
相關(guān)推薦

2023-12-18 09:15:58

CSS前端容器查詢

2023-03-27 09:25:21

CSS自定義彩色字體

2017-04-07 11:45:25

CSSDIV前端

2023-07-28 10:21:46

CSS前端

2022-12-12 11:11:05

2022-08-02 06:39:06

多行文本CSS

2010-09-08 12:49:16

CSS斜線

2021-05-19 06:07:21

CSS 斜線效果技巧

2010-09-09 10:23:23

DIVCSS垂直居中

2021-08-30 07:57:26

OpenAttack文本對抗攻擊

2010-09-09 11:16:06

CSS交互

2010-09-09 12:49:58

鼠標(biāo)懸停tip效果CSS

2010-08-24 14:47:48

CSS居中

2010-09-14 09:18:28

DIVCSS

2010-09-07 14:53:45

Chroma屬性CSS

2010-09-14 12:58:41

DIV+CSS圓角

2021-12-27 07:45:30

CSS 技巧煙霧效果

2021-01-19 12:16:10

CSS前端UI

2023-02-20 09:48:00

CSS浮動布局

2022-10-24 17:57:06

CSS容器查詢
點贊
收藏

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

主站蜘蛛池模板: 精品亚洲一区二区三区四区五区高 | 亚洲视频一区二区三区 | 一级片在线视频 | 精品久久久久久久人人人人传媒 | 国产精品亚洲第一区在线暖暖韩国 | 精品在线99 | 高清一区二区三区 | 亚洲另类视频 | av一区在线观看 | 中文字幕在线观看第一页 | 日本不卡免费新一二三区 | 国产欧美精品区一区二区三区 | 日韩成人免费 | 日韩国产一区二区三区 | 成人免费精品 | 国产精品久久久久久久久久久久久 | 国产欧美一区二区三区在线看蜜臀 | 亚洲国产aⅴ精品 | zzzwww在线看片免费 | 涩涩操 | 亚洲国产精品一区二区第一页 | 在线中文视频 | 亚洲成人三级 | 精品欧美一区二区三区久久久 | 精品欧美一区二区三区久久久 | 亚洲手机视频在线 | 成人午夜视频在线观看 | 免费欧美视频 | 二区三区av | 精品国产乱码久久久久久老虎 | 日韩欧美电影在线 | 91精品综合久久久久久五月天 | 久久成人精品视频 | 丝袜美腿一区二区三区动态图 | 欧美精品乱码久久久久久按摩 | 999视频| 黄色毛片大全 | 久久蜜桃av一区二区天堂 | www97影院| 久久99蜜桃综合影院免费观看 | 久久久国产视频 |