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

368 阅读1分钟

通过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)); // 是否展示省略号(...)