CSS 如何实现多行文本展开收起效果

开发 前端
如果包含块的高度显式指定,则设置该元素为绝对定位:包含块的高度是动态的,没办法显式指定,所以此方法也不可用。

[[413428]]

本文转载自微信公众号「三分钟学前端」,作者sisterAn 。转载本文请联系三分钟学前端公众号。

最终实现效果:

本文主要实现难点:

  • 如何实现 展开 和 收起 切换按钮的文字环绕效果
  • 如何实现多行文本溢出省略效果
  • 如何实现 展开 和 收起 的状态or文字切换

初始 html:

  1. <div class="text"
  2.   <label class="btn">展开</label> 
  3.   <span> 
  4.     但听得蹄声如雷,十余乘马疾风般卷上山来。马上乘客一色都是玄色薄毡大氅, 
  5.     里面玄色布衣,但见人似虎,马如龙,人既矫捷,马亦雄骏,每一匹马都是高头 
  6.     长腿,通体黑毛,奔到近处,群雄眼前一亮,金光闪闪,却见每匹马的蹄铁竟然 
  7.     是黄金打就。来者一共是一十九骑,人数虽不甚多,气势之壮,却似有如千军万 
  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> 

 

 

控制按钮文字环绕效果

一般展开、收起按钮都在文字的右下脚:

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

但 margin 虽然可以将按钮局下,但它无法实现文字环绕效果,所以我们这里利用伪元素实现:

  • 局右: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); 

我们发现出现了高度塌陷( calc(100% - 20px) 无效)的问题:

由于包含块的高度没有显式指定,并且该元素不是绝对定位,则计算值伪 auto,auto * 100/100 = NaN

— CSS 世界

此时解决办法有:

  • 设置显式的高度值:这里高度是动态的,没办法显式指定,所以此方法不可用?
  • 如果包含块的高度显式指定,则设置该元素为绝对定位:包含块的高度是动态的,没办法显式指定,所以此方法也不可用?
  • 在元素外边包一层具有包裹性又具有定位特性的标签:?

这里包一层 flex 布局。因为在 flex 布局的子项中,可以通过百分比来计算变化高度,因此,这里需要给 .text 包裹一层,然后设置 display: flex

  1. <div class="content"
  2.  <div class="text"
  3.    <label class="btn" for="exp">展开</label> 
  4.    <span> 
  5.      但听得蹄声如雷,十余乘马疾风般卷上山来。马上乘客一色都是玄色薄毡大氅, 
  6.      里面玄色布衣,但见人似虎,马如龙,人既矫捷,马亦雄骏,每一匹马都是高头 
  7.      长腿,通体黑毛,奔到近处,群雄眼前一亮,金光闪闪,却见每匹马的蹄铁竟然 
  8.      是黄金打就。来者一共是一十九骑,人数虽不甚多,气势之壮,却似有如千军万 
  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 实现文本的单行和多行溢出省略效果 介绍过:

多行文本(css)

  1. .text { 
  2.   display: -webkit-box; 
  3.   overflow: hidden; 
  4.   -webkit-line-clamp: 3; 
  5.   -webkit-box-orient: vertical; 
  • -webkit-line-clamp: 3(用来限制在一个块元素显示的文本的行数, 2 表示最多显示 2 行。为了实现该效果,它需要组合其他的WebKit属性)
  • display: -webkit-box(和 1 结合使用,将对象作为弹性伸缩盒子模型显示 )
  • -webkit-box-orient: vertical(和 1 结合使用 ,设置或检索伸缩盒对象的子元素的排列方式 )
  • overflow: hidden(文本溢出限定的宽度就隐藏内容)
  • text-overflow: ellipsis(多行文本的情况下,用省略号“…”隐藏溢出范围的文本)

如何实现 展开 和 收起 的状态切换

使用 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; /*设置一个足够大的行数就可以了*/ 
  9.   } 
  10. </style> 

但文字展开后控制按钮依然显示 展开 ,应该显示 收起 才对

这里使用伪类生成技术,具体做法就是去除或者隐藏按钮里面的文字,采用伪元素生成

  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> 

最终,大功告成:

 

责任编辑:武晓燕 来源: 三分钟学前端
相关推荐

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-09 10:23:23

DIVCSS垂直居中

2010-09-08 12:49:16

CSS斜线

2021-05-19 06:07:21

CSS 斜线效果技巧

2021-08-30 07:57:26

OpenAttack文本对抗攻击

2021-01-19 12:16:10

CSS前端UI

2010-09-14 12:58:41

DIV+CSS圆角

2010-09-07 14:53:45

Chroma属性CSS

2021-12-27 07:45:30

CSS 技巧烟雾效果

2010-09-14 09:18:28

DIVCSS

2023-07-05 16:07:02

JavaScriptWeb 应用程序

2023-02-20 09:48:00

CSS浮动布局

2022-10-24 17:57:06

CSS容器查询

2010-08-24 14:47:48

CSS居中

2010-09-09 11:16:06

CSS交互
点赞
收藏

51CTO技术栈公众号