百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

css实现多行文本的展开收起

moboyou 2025-06-18 18:36 9 浏览

背景

在我们写需求时可能会遇到类似于这样的多行文本展开与收起的场景:

那么,如何通过纯css实现这样的效果呢?

实现的难点

(1)位于多行文本右下角的 展开收起按钮

(2)展开和收起两种状态的切换。

(3)文本不超过指定行数时不展示 展开收起按钮

一、位于右下角的“展开收起”按钮

多行文本截断

假设有这样一个结构:

<div className="text">
    银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,
</div>

多行文本超出省略,主要用到用到 line-clamp,关键样式如下:

.text {
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
}

右下角环绕效果

下面放一个按钮,然后设置浮动,可以使文本环绕按钮,在通过一个 margin-top 可以使按钮移动到右下角

<div className="text">
    <button className="btn">展开</button>
    银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银,银泰百货,银,银泰百货,银,银泰百货,银,银泰百货,银,银泰百货,银,银泰百货,银
</div>
<style>
.btn{
    float:right;
    margin-top:50px;
}
</style>

可以看到,虽然按钮到了右下角,但是文本却没有环绕按钮上方的空间,空出了一大截

此时我们可以通过多个浮动元素进行调整,这里用伪元素 ::before 来代替

<style>
.text:before{
    content:'';
    float:right;
    width:10px;
    height:58px;/*先随便设置一个高度*/
    background:red
}
</style>

通过清除浮动使伪元素位于按钮的上方

<style>
.btn{
    float:right;
    clear:both;
}
</style>

可以看到,现在文本是完全环绕在右侧的两个浮动元素了,只要把红色背景的伪元素宽度设置为0(或者不设置宽度,默认就是 0),就实现了右下角环绕的效果

<style>
.text:before{
    content:'';
    float:right;
    width:0;/*设置为0,或者不设置宽度*/
    height: 50px;/*先随便设置一个高度*/
}
</style>

动态高度

上面虽然完成了右下加环绕,但是高度是固定的,如何动态设置呢?

这里可以用到 calc 计算,用整个容器高度减去按钮的高度即可,如下:

<style>
.text:before{
    content:'';
    float:right;
    width:0;/*设置为0,或者不设置宽度*/
    height: calc(100% - 24px);/*先随便设置一个高度*/
}
</style>

很可惜,好像并没有什么效果,打开控制台看看,结果发现 calc(100% - 24px) 计算高度为 0

原因就是高度 100% 失效的问题,关于这类问题网上的分析有很多

通常的解决方式是给父级指定一个高度,但是这里的高度是动态变化的,而且还有展开状态,高度更是不可预知,所以设置高度不可取。

除此之外,其实还有另一种方式,那就是利用 flex 布局

因此,这里需要给 .text 包裹一层,然后设置 display: flex

<div className="wrap">
    <div className="text">
        <button className="btn">展开</button>
        银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银,银泰百货,银,银泰百货,银,银泰百货,银,银泰百货,银,银泰百货,银,银泰百货,银
    </div>
</div>
<style>
.wrap{
    display :flex;
}
</style>

这样下来,刚才的计算高度就生效了,改变文本的行数,同样位于右下角

二、“展开”和“收起”两种状态

CSS 状态切换,需要用到 input type="checkbox"

我们首先加一个 input,然后把之前的 button 换成 label ,并且通过 for 属性关联起来。

注意!在 jsx 语法中 for 属性要写成 htmlFor

<div className="wrap">
    <input type="checkbox" id="exp">
    <div className="text">
        <label className="btn" htmlFor="exp">展开</label>
        银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银泰百货,银,银泰百货,银,银泰百货,银,银泰百货,银,银泰百货,银,银泰百货,银,银泰百货,银
    </div>
</div>

这样,在点击 label 的时候,实际上是点击了 input 元素

现在来添加两种状态,分别是只显示 2 行和不做行数限制

<style>
.exp:checked+.text{
    -webkit-line-clamp: 999; /* 设置一个足够大的行数即可 */
}
</style>

兼容版本可以直接设置最大高度 max-height 为一个较大的值,或者直接设置为 none

<style>
.exp:checked+.text{
    max-height:none;
}
</style>

展开 按钮在点击后应该变成 收起 ,使用 伪类 content 生成技术

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

<label class="btn" for="exp"></label> <!-- 去除按钮文字 -->

<style>
.btn::after{
    content:"展开"; /* 采用content 生成 */
}
</style>

添加 .checked 状态

<style>
.exp:checked+.text .btn::after{
    content:"收起";
}
</style>

三、文本行数的判断

当文本较少时,此时是没有发生截断,需要隐藏展开按钮,CSS 是没有这类逻辑判断

大多数我们都需要从别的角度,采用 “障眼法” 来实现

在文本末尾添加一个元素,为了不影响原有布局,这里设置了绝对定位,这里用 .text::after 伪元素来代替

把刚才这个元素设置一个足够大的尺寸,比如 100% * 100%

<style>
.text::after{
    content: ' ';
    width:100%;
    height:100%;
    position: absolute;
    background: #fff;
}
</style>

那么如果此时文本没有截断,这个元素会把按钮覆盖掉,如果有截断,这个元素会往下移,就不会覆盖按钮

点击展开后按钮丢失,无法收起

此时,我们可以添加一下:checked状态即可,在展开时隐藏覆盖层

<style>
.exp:checked+.text::after{
    visibility:hidden;
}
</style>

这样,就实现了在文字较少的情况下隐藏展开按钮的功能

相关推荐

discuz!论坛系统项目安装手册(discuz论坛纯白简约模板)

云服务器部署论坛系统discuz1.Logo2.安装LAMP[root@apache~]#yum-yinstallhttpdmariadb-servermariadbphpphp-...

2025年数据安全新趋势:10种防泄漏方法守护企业机密

1.Ping32:一体化数据安全防护专家Ping32构建起一体化数据安全防护体系,宛如为企业打造了一座坚不可摧的数据堡垒。它集文档智能加密、DLP与实时态势感知于一身,全方位守护企业数据安全。文...

篡改企业系统数据!男子非法获利20余万元被批捕

在数字化时代,网络技术的迅猛发展给我们的生活带来了便利,但同时也伴随着一些不法分子的恶行。近日,雨花区人民检察院通报一起关于犯罪嫌疑人邓某利用技术手段篡改系统数据,来牟取利益的案件。案情回顾邓某,原本...

生物识别信息纳入电子数据剑指网络犯罪 最高检副检察长就办理网络犯罪案件规定答记者问

最高人民检察院近日发布《人民检察院办理网络犯罪案件规定》(以下简称《规定》)。2月26日,就《规定》出台的背景、网络犯罪案件审查的特点等有关问题,最高检副检察长孙谦回答了记者提问。记者:请您介绍一下发...

“网红AI”写作技巧惊人?英媒:大学生用其完成考试答题能拿满分

【环球时报综合报道】人工智能研究机构OpenAI日前发布的全新聊天机器人模型ChatGPT,不仅会自动修复bug,还拥有华丽的写作技巧,面对各种话题都能侃侃而谈,迅速成为“网红AI”。2015年,马斯...

在移动端轻松查看网页源代码:View Source 2.0

如果你是一名站长或Web开发者,在浏览器中查看网页源代码(HTML、CSS与JavaScript)是每天必不可少的操作,这个在桌面端轻而易举的操作到了移动端却变成了一件麻烦事。如今有了Vie...

基于Python的邮件管理系统设计与实现-计算机毕业设计源码+LW文档

摘要电子邮件,作为信息化时代的核心沟通工具,对日常生活与工作具有深远的影响。这个互联网技术下的产物,尽管为全球网络用户带来了沟通上的便利,但同时也面临着许多的挑战。尤其是是信息爆炸导致的邮件过多、垃...

半成品游戏源代码185.77万元起拍?拍卖方:原公司开发曾投入超千万元

近日,阿里司法拍卖网挂出一宗特殊标的——开发程度仅为40%,名为《代号:TD》的游戏的源代码及部分美术资源,起拍价185.77万元。有网友截图发到社交平台引发热议。100多万元的高价与“残缺项目”的反...

谷歌变更安卓平台开发流程 否认转向闭源 会对行业产生什么影响?

“谷歌将终止开源安卓”的消息这两天在网上引发广泛关注。但谷歌在一封与合作伙伴的沟通信中表示,虽然对安卓开发模式进行了变更,并不意味着将转向闭源。那么,这样的改变到底会对行业产生什么样的影响呢?我们来听...

白山云科技:云抗D、云WAF没效果?警惕源IP暴露

互联网攻防之战已经持续了数十年,随着企业安全意识的提高、安全措施的完善,各类安全防护产品以及云安全厂商为企业业务架起了一面“安全之盾”,阻挡着网络空间中的危机风险。然而,近期时常发生令企业用...

Foxmail『快捷键』运用知多少?(foxmail发送邮件快捷键)

本文主要介绍关于Foxmail客户端快捷键的运用。系统默认快捷键如下所示:主窗口打开邮件Ctrl+O写新邮件Ctrl+N收取当前邮箱的邮件F2收取所有邮箱的邮件F4回复Ctrl+R回复所有...

俄罗斯黑客获得了微软的电子邮件和源代码

微软这家Windows公司几周前就发现了犯罪分子对其系统的访问,而且它无法摆脱明显的俄罗斯攻击者。这会产生后果。微软并没有将俄罗斯黑客从其系统中清除,这些黑客最近访问了该公司一些高级管理人员的电子邮件...

Gmail API配置+Python实现google邮件发送完整指南,出海必备!

最近在做个海外项目,需要使用邮箱通知功能!最开始时候用的163邮箱发现各种收件延迟,无奈之下决定弃用国内邮箱,改用海外最大用户平台谷歌的gmail进行邮件发送。不过登录最新的Gmail邮箱设置界面,可...

在电影里,一封电子邮件人命攸关丨夜问

答案:从上至下剧照分别来自电影《电子情书》《源代码》《隐形人》《实习生》。《电子情书》中,男女主角靠电子邮件相识、相爱。《源代码》男主角最后一次进入平行时空后给女军官古德温发了一封邮件,告诉她源代码可...

Python数据分析实战-正则提取文本的URL网址和邮箱(源码和效果)

实现功能:Python数据分析实战-利用正则表达式提取文本中的URL网址和邮箱实现代码:importre#python正则表达式提取网址myString='https://gith...