多行展示以省略号(...)处理

简介: 多行展示以省略号(...)处理

通过JS计算字符串在浏览器中显示的宽度。

将文本数据,通过先生成dom,然后获取dom的宽度,即可拿到整个文本的宽度。

然后通过获取屏幕宽度,计算所需要的行数,算出总行数的宽度。

两者对比,判断是否需要展示省略号(...)。

function calculateData(text, line){
    let cWidth = document.body.clientWidth;
    let tWidth = parseFloat((cWidth * line).toFixed(2));
    let span = document.createElement('span');
    span.innerHTML = text;
    span.style.visibility = 'hidden';
    span.setAttribute('class','fontSize');
    document.body.appendChild(span);
    const $dom = document.getElementsByClassName('fontSize')[0];
    let swidth = $dom.offsetWidth;
    document.getElementsByTagName('body')[0].removeChild($dom);
    return tWidth < swidth;
}
const str = '多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示多行展示';
console.log(calculateData(str, 2)); // 是否展示省略号(...)
目录
相关文章
|
前端开发 机器人 API
前端大模型入门(一):用 js+langchain 构建基于 LLM 的应用
本文介绍了大语言模型(LLM)的HTTP API流式调用机制及其在前端的实现方法。通过流式调用,服务器可以逐步发送生成的文本内容,前端则实时处理并展示这些数据块,从而提升用户体验和实时性。文章详细讲解了如何使用`fetch`发起流式请求、处理响应流数据、逐步更新界面、处理中断和错误,以及优化用户交互。流式调用特别适用于聊天机器人、搜索建议等应用场景,能够显著减少用户的等待时间,增强交互性。
5204 2
|
数据采集
数学建模之数据预处理-------数据异常值的处理
数学建模之数据预处理-------数据异常值的处理
|
存储 Java API
淘宝拍立淘图片搜索接口:轻松找到同款商品!
淘宝拍立淘图片搜索接口:轻松找到同款商品!
|
SQL 关系型数据库 MySQL
Python 与 MySQL 进行增删改查的操作以及防止SQL注入
Python 与 MySQL 进行增删改查的操作以及防止SQL注入
673 0
Flyway Validate failed: Migration checksum mismatch for migration version 1.0.0.01 错误
在运行系统的时候出现错误: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'flywayInitializer' defined in class path resour...
3194 0
|
Java Linux
Flume【环境搭建 01】CentOS Linux release 7.5 安装配置 apache-flume-1.9.0 并验证
【2月更文挑战第16天】Flume【环境搭建 01】CentOS Linux release 7.5 安装配置 apache-flume-1.9.0 并验证
485 0
|
存储 弹性计算 安全
阿里云七代云服务器计算型c7、通用型g7、内存型r7实例性能介绍及活动价格参考
阿里云第7代云服务器主要实例规格包括计算型c7、通用型g7、内存型r7,其中计算型c7实例适用于计算密集型业务,如Web服务器Apache、Nginx等场景,通用型g7实例适用于通用业务,如网站应用、各类企业级应用、中间件,内存型r7实例适用于内存密集型业务,如数据库系统、缓存、搜索集群。本文为大家详细介绍七代云服务器实例的主要性能和最新活动价格情况。
阿里云七代云服务器计算型c7、通用型g7、内存型r7实例性能介绍及活动价格参考
|
SQL 存储 数据库
达梦(DM) SQL调优
【1月更文挑战第2天】达梦(DM) SQL调优
|
canal 存储 缓存
如何优雅的记录操作日志
操作日志几乎存在于每个系统中,而这些系统都有记录操作日志的一套 API。操作日志和系统日志不一样,操作日志必须要做到简单易懂。所以如何让操作日志不跟业务逻辑耦合,如何让操作日志的内容易于理解,如何让操作日志的接入更加简单?上面这些都是本文要回答的问题。我们主要围绕着如何“优雅”地记录操作日志展开描述,希望对从事相关工作的同学能够有所帮助或者启发。
1210 0
如何优雅的记录操作日志
|
Ubuntu 网络安全 开发工具
[vscode] --- vscode remote ssh远程登陆设置
[vscode] --- vscode remote ssh远程登陆设置
932 0
[vscode] --- vscode remote ssh远程登陆设置