css文本溢出处理——单行、多行

日常开发中,经常会遇到需要展示的文本过长,这种情况下,为了提高用户的使用体验,最常见的处理方式就是把溢出的文本显示成省略号。

处理文本的溢出的方式:1)单行文本溢出; 2)多行文本溢出; 3)超出容器高度缩略展示;4)缩略后加展开收起按钮可点击操作。

一、单行文本溢出省略

1、主要的css属性:

overflow:文字长度超出限定宽度,则隐藏超出的内容

  • visible: 默认值。内容不会回修剪,可以呈现在元素框之外。
  • scroll: 无论是否超出容器,都会出现一个滚动条。
  • auto: 如果没有超出容器的显示,将会正常显示,如果超出,将会出现一个滚动条。
  • hidden: 如果内容超出父级容器,超出部分将会被隐藏

text-overflow:规定当文本溢出时,显示省略符号来代表被修剪的文本

  • clip:当对象内文本溢出部分裁切掉
  • ellipsis:当对象内文本溢出时显示省略标记(…)
    注意:只有在设置了overflow:hiddenwhite-space:nowrap后text-overflow才能够生效的

white-space:控制空白字符的显示,同时还能控制是否自动换行。

  • normal: 连续的空白符会被合并,换行符会被当作空白符来处理。
  • nowrap:和 normal 一样,连续的空白符会被合并,但文本内的换行无效。
    在实现单行文本缩略展示时作用是设置文本不换行,是overflow:hidden和text-overflow:ellipsis生效的基础。
  • pre: 连续的空白符会被保留,仅在遇到换行符或 br标签时才会换行。
  • pre-wrap: 连续的空白符会被保留。
  • pre-line: 连续的空白符会被合并。

word-break: break-all 使一个单词能够在换行时进行拆分。

2、具体实现

在这里插入图片描述

<div class="wrap"><p>单行文本溢出缩略显示</p><div class="one-line">人们总是把幸福解读为“有”,有房,有车,有钱,有权,但幸福其实是“无”,无忧,无虑,无病,无灾,“有”多半是给别人看的,“无”才是你自的。</div>
</div><style>
.wrap {width: 350px;margin: 0 auto;text-align: left;
}
p {color: #1989fa;
}
.one-line {text-overflow: ellipsis;overflow: hidden;word-break: break-all;white-space: nowrap;border: 1px solid #eef0f5;
}
</style>

二、多行文本溢出省略

在这里插入图片描述

<div class="wrap"><p>两行省略——基于行数截断</p><div class="two-line">土地是世界上唯一值得你去为之工作,为之战斗,为之牺牲的东西。 Land is theonly thing in the world worth working for, worth fighting for, worth dyingfor.</div>
</div><style>
.two-line {overflow: hidden;display: -webkit-box; /* 将对象作为弹性伸缩盒子模型显示 */-webkit-line-clamp: 2; /* 行数,值可以改,表示展示X行后多余的缩略展示 */-webkit-box-orient: vertical; /* 设置或检索伸缩盒对象的子元素的排列方式 */word-break: break-all;border: 1px solid #eef0f5;
}
</style>

三、超过元素宽高省略显示

简单来说,超过元素宽高度后缩略展示,关键在于需要设置元素宽度与高度,然后再根据高度看下最多能放几行,设置-webkit-line-clamp的值为最大行数。
在这里插入图片描述

<div class="wrap"><p>超过元素宽高省略显示</p><div class="limit-height">现在我发现自己活在一个比死还要痛苦的世界,一个无我容身之处的世界。 Now Ifind myself in a world which for me is worse than death. A world in whichthere is no place for me.</div>
</div><style>
.limit-height {width: 350px; height: 65px;word-break: break-all;overflow: hidden;display: -webkit-box; -webkit-line-clamp: 3;-webkit-box-orient: vertical; border: 1px solid #eef0f5;
}
</style>

四、纯css实现文本展开 / 收起

在这里插入图片描述

<div class="hide-or-expend"><input id="expend" class="expend" type="checkbox" /><div class="content"><label class="btn" for="expend"></label>有时起初的隐忍可以避免一路的疼痛。 Sometimes a little discomfort in thebeginning can save a whole lot of pain down the road.有人住高楼,有人在深沟,有人光万丈,有人一身锈,世人万千种,浮云莫去求,斯人若彩虹,遇上方知有。Some of us get dipped in flat, some in satin, some in gloss. But everyonce in a while you find someone who's iridescent, and when you do,nothing will ever compare.</div>
</div><style>
.hide-or-expend {display: flex;width: 350px;margin: 50px auto;overflow: hidden;text-align: left;border: 1px solid #eef0f5;
}
.content {position: relative;overflow: hidden;text-overflow: ellipsis;display: -webkit-box;-webkit-line-clamp: 3;-webkit-box-orient: vertical;
}
.content::before {content: "";height: calc(100% - 23px);float: right;
}
.content::after {position: absolute;content: "";width: 999vw;height: 999vw;
}
.btn {float: right;clear: both;color: #1989fa;cursor: pointer;
}
.btn::before {content: "展开";
}
.expend {display: none;
}
.expend:checked + .content {-webkit-line-clamp: 999;
}
.expend:checked + .content::after {visibility: hidden;
}
.expend:checked + .content .btn::before {content: "收起";
}
</style>

参考文章:https://segmentfault.com/a/1190000040030723

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/317043.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

快速打通 Vue 3(三):Vue3 中的 watch 监听器与新特性

很激动进入了 Vue 3 的学习&#xff0c;作为一个已经上线了三年多的框架&#xff0c;很多项目都开始使用 Vue 3 来编写了 这一组文章主要聚焦于 Vue 3 的新技术和新特性 如果想要学习基础的 Vue 语法可以看我专栏中的其他博客 Vue&#xff08;一&#xff09;&#xff1a;Vue 入…

《低功耗方法学》翻译——卷首语

就目前半导体的发展现状来说&#xff0c;我们国家还处在奋力追赶阶段。在我国半导体行业历经多轮技术制裁的今天&#xff0c;我们不得不承认的是&#xff0c;半导体技术最先进的就是美国。我国早在上世纪六七十年代就有涉足半导体技术&#xff0c;大量华裔留美的爱国人士回国为…

清风数学建模笔记-因子分析

内容&#xff1a;因子分析 概念&#xff1a; 通过分析研究变量间的相关系数矩阵&#xff0c;把这些变量间错综复杂的关系归结成少数几个综合因子&#xff0c;由于归结出的因子个数少于原始变量的个数&#xff0c;但是又包含原始变量的信息&#xff0c;所以这一过程也称之为降…

Django Web框架

1、创建PyCharm项目 2、安装框架 pip install django4.2.0 3、查看安装的包列表 4、使用命令创建django项目 django-admin startproject web 5、目录结构 6、运行 cd web python manage.py runserver7、初始化后台登录的用户名密码 执行数据库迁移生成数据表 python man…

Objects are not valid as a React child (found: object with keys {name}).

在jsx中可以嵌套表达式&#xff0c;将表达式作为内容的一部分&#xff0c;但是要注意&#xff0c;普通对象不能作为子元素&#xff1b;但是数组&#xff0c;react元素对象是可以的 如下&#xff1a;不能将stu这个对象作为子元素放 function App() {const myCal imgStyleconst…

sentinel控制面板dashboard的下载安装教程

目录 一、dashboard控制面板下载二、启动dashboard 一、dashboard控制面板下载 资源下载地址: https://github.com/alibaba/Sentinel/releases 也可以点击这里进行下载&#xff0c;无需积分 找到需要下载的版本&#xff0c;展开下面的资源Assets&#xff0c;下载sentinel-das…

NSSCTF Http pro max plus

开启环境: 进去显示只允许本地访问,打开bp: 请求头写 x-forwarded-for: 127.0.0.1 换一种 client-ip: 127.0.0.1 执行显示 You are not from pornhub.com ! 请求头写 referer: pornhub.com 执行显示 不开代理你想上p站&#xff1f; 代理服务器地址是Clash.win ,请求头写 via: …

手把手教你学会接口自动化框架的搭建-前言

在网上看过很多帖子,各种接口自动化的框架眼花缭乱,但是对于很多才做自动化的新手,那是一头雾水。 因此,我决定出一个系列,让你能够按照我的文档一步步把接口自动化都做起来,而不是网上这种一股脑的全部抛出,让你看的云里雾里的。 看完这些文档保证你能去任何一家公司,…

BWP频域位置的确定

这里根据协议整理下BWP频域相关参数以及如何确定BWP的频域位置。 BWP的配置包含几个参数 &#xff1a; 1 SCS, CyclePrefix 和locationAndBandwidth。 BWP频域起始位置N_start_BWPOcarrierRBstart&#xff0c;其中Ocarrier 由RRC层参数offsetToCarrier决定。 locationAndB…

清风数学建模-数学规划模型

内容&#xff1a;数学规划模型&#xff08;cab aeqbeq lbub&#xff09; 一.题型类型 1.线性规划linprog 2.非线性规划 fmincon 3.整数规划 intlinprog 4.&#xff08;0-1规划&#xff09;&#xff08;特殊的线性整数规划&#xff09;intlinprog 5.多目标规划 linprog 标…

BIO和NIO编程(待完善)

目录 IO模型 BIO NIO 常见问题 IO模型 Java共支持3种网络编程IO模式&#xff1a;BIO&#xff0c;NIO&#xff0c;AIO BIO 同步阻塞模型&#xff0c;一个客户端连接对应一个处理线程 代码示例&#xff1a; Server端&#xff1a; public class BioServer {private static …

学到了!3步get微信自动回复

你是不是也有过这样的烦恼&#xff1a;因为忙碌或是消息太多&#xff0c;没能及时回复好友消息&#xff0c;尤其是在休息、节假日的时候。 今天就给大家种草一款能够让微信自动回复消息的神器——微信管理系统&#xff0c;让你再忙碌也能及时回复好友&#xff01;而且操作也不…