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

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

通过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)); // 是否展示省略号(...)
目录
相关文章
|
8月前
|
前端开发
CSS 限制文字行数(超出显示省略号...)
CSS 限制文字行数(超出显示省略号...)
79 0
|
JavaScript 前端开发
js 文字超出长度用省略号代替,鼠标悬停并以悬浮框显示
js 文字超出长度用省略号代替,鼠标悬停并以悬浮框显示
|
2月前
|
前端开发
CSS文本单行溢出显示省略号与多行溢出显示省略号(简单易懂)
CSS文本单行溢出显示省略号与多行溢出显示省略号(简单易懂)
|
5月前
div 文字溢出文字自动隐藏显示
div 文字溢出文字自动隐藏显示
测试图片随文字上下居中
测试图片随文字上下居中
|
5月前
|
Linux
文字的显示
文字的显示
90 0
|
前端开发
css实现文字或内容溢出展示省略号
css实现文字或内容溢出展示省略号
85 0
|
容器
p标签字数过多显示省略号
p标签字数过多显示省略号
681 0
|
前端开发
多行文本溢出显示省略号(…) +css样式
多行文本溢出显示省略号(…) +css样式
134 0
多行文本溢出显示省略号(…) +css样式