多行文本溢出解决方案总结

最近开发页面遇到一个问题,产品要求页面的布局按照文字的行数显示,之前我们都是按照字数进行显示,按行显示就涉及到了适配等问题,于是研究了一下。

前端开发应该都知道用text-overflow:ellipsis属性来实现单行文本的溢出显示省略号(…)。当然部分浏览器还需要加宽度width属性。

1 overflow: hidden;
2 text-overflow: ellipsis;
3 white-space: nowrap;

但是这个属性并不支持多行文本溢出显示省略号,这里根据应用场景介绍几个方法来实现这样的效果。

WebKit浏览器或移动端的页面

在WebKit浏览器或移动端(绝大部分是WebKit内核的浏览器)的页面实现比较简单,可以直接使用WebKit的CSS扩展属性(WebKit是私有属性)-webkit-line-clamp ,值得注意的是:这是一个不规范的属性,它没有出现在 CSS 规范草案中。

-webkit-line-clamp用来限制在一个块元素显示的文本的行数。 为了实现该效果,它需要组合其他的WebKit属性

常见结合属性:

    1. display: -webkit-box; 必须结合的属性 ,将对象作为弹性伸缩盒子模型显示 。
    2. -webkit-box-orient 必须结合的属性 ,设置或检索伸缩盒对象的子元素的排列方式 。
    3. text-overflow: ellipsis;,可以用来多行文本的情况下,用省略号“…”隐藏超出范围的文本 
1 overflow : hidden;
2 text-overflow: ellipsis;
3 display: -webkit-box;
4 -webkit-line-clamp: 2;
5 -webkit-box-orient: vertical;

这个属性比较合适WebKit浏览器或移动端(绝大部分是WebKit内核的)浏览器。

JavaScript 方案

用js也可以根据上面的思路去模拟,实现也很简单,推荐几个做类似工作的成熟小工具:

1.Clamp.js

下载及文档地址:https://github.com/josephschmitt/Clamp.js
使用也非常简单:

1 var module = document.getElementById("clamp-this-module");
2 $clamp(module, {clamp: 3});

2.jQuery插件-jQuery.dotdotdot

下载及文档地址:https://github.com/BeSite/jQuery.dotdotdothttp://dotdotdot.frebsite.nl/

这个使用起来也很方便:

1 $(document).ready(function() {
2     $("#wrapper").dotdotdot({
3         //  configuration goes here
4     });
5 });

本次因为移动端的页面,所以采用的是 webkit 的方式进行处理。

作者:旧旧的 <393210556@qq.com> 解决问题的方式,就是解决它一次

原文地址:https://www.cnblogs.com/widgetbox/p/10756220.html