CSS 如何实现多行文本展开收起效果
思路
最终效果
主要难点:
- 如何实现
展开
和收起
切换按钮的文字环绕效果 - 如何实现
多行文本溢出省略
效果 - 如何实现
展开
和收起
的状态or文字切换
初始html:
<div class="text"> |
一、控制按钮文字环绕效果
一般展开、收起按钮都在文字的右下脚:
- 居右:
float: right
- 居下:
margin-top
但 margin
虽然可以将按钮局下,但它无法实现文字环绕效果,所以我们这里利用伪元素实现:
- 居右:
float: right
- 居下:
.text::before
.text::before{ |
.text::before{ |
我们发现出现了高度塌陷( calc(100% - 20px)
无效)的问题:
此时解决办法有:
- 设置显式的高度值:这里高度是动态的,没办法显式指定,所以此方法不可用❌
- 如果包含块的高度显式指定,则设置该元素为绝对定位:包含块的高度是动态的,没办法显式指定,所以此方法也不可用❌
- 在元素外边包一层具有包裹性又具有定位特性的标签:✅
这里包一层 flex 布局。因为在 flex 布局的子项中,可以通过百分比来计算变化高度,因此,这里需要给 .text
包裹一层,然后设置 display: flex
<div class="content"> |
<style> |
二、多行文本溢出省略效果
我们在 CSS 实现文本的单行和多行溢出省略效果 介绍过:
多行文本(css)
.text { |
-webkit-line-clamp: 3
(用来限制在一个块元素显示的文本的行数, 2 表示最多显示 2 行。为了实现该效果,它需要组合其他的WebKit属性)display: -webkit-box
(和 1 结合使用,将对象作为弹性伸缩盒子模型显示 )-webkit-box-orient: vertical
(和 1 结合使用 ,设置或检索伸缩盒对象的子元素的排列方式 )overflow: hidden
(文本溢出限定的宽度就隐藏内容)text-overflow: ellipsis
(多行文本的情况下,用省略号“…”隐藏溢出范围的文本)
三、如何实现 展开
和 收起
的状态切换
使用 input type="checkbox"
控制展开与收起效果
<input type="checkbox" id="exp" /> |
但文字展开后控制按钮依然显示 展开
,应该显示 收起
才对
这里使用伪类生成技术,具体做法就是去除或者隐藏按钮里面的文字,采用伪元素生成
<label class="btn" for="exp"></label> |
最终,大功告成:
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 Alanni!
评论