第 206 题:如何实现多行文本 展开收起 效果?
为了排版美观,将长文本和短文本统一样式展示,这是很多 APP 的基本布局方式。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
为了排版美观,将长文本和短文本统一样式展示,这是很多 APP 的基本布局方式。
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
接受
或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
发布评论
评论(3)
https://juejin.cn/post/7022876094608982030
最终实现效果:
本文主要实现难点:
展开
和收起
切换按钮的文字环绕效果展开
和收起
的状态切换初始 html:
控制按钮文字环绕效果
一般展开、收起按钮都在文字的右下脚:
float: right
margin-top
但
margin
虽然可以将按钮局下,但它无法实现文字环绕效果,所以我们这里利用伪元素实现:float: right
.text::before
局右
局下
我们发现出现了高度塌陷(
calc(100% - 20px)
无效)的问题:此时解决办法有:
这里包一层 flex 布局。因为在 flex 布局的子项中,可以通过百分比来计算变化高度,因此,这里需要给
.text
包裹一层,然后设置display: flex
多行文本溢出省略效果
我们在 CSS 实现文本的单行和多行溢出省略效果 介绍过:
多行文本(css)
-webkit-line-clamp: 3
(用来限制在一个块元素显示的文本的行数, 2 表示最多显示 2 行。 为了实现该效果,它需要组合其他的WebKit属性)display: -webkit-box
(和 1 结合使用,将对象作为弹性伸缩盒子模型显示 )-webkit-box-orient: vertical
(和 1 结合使用 ,设置或检索伸缩盒对象的子元素的排列方式 )overflow: hidden
(文本溢出限定的宽度就隐藏内容)text-overflow: ellipsis
(多行文本的情况下,用省略号“…”隐藏溢出范围的文本)如何实现
展开
和收起
的状态切换使用
input type="checkbox"
控制展开与收起效果但文字展开后控制按钮依然显示
展开
,应该显示收起
才对这里使用伪类生成技术,具体做法就是去除或者隐藏按钮里面的文字,采用伪元素生成
最终,大功告成:
原文
toggle:
1、判断高度
2、判断字符数