zoukankan      html  css  js  c++  java
  • 多行文本溢出解决方案总结

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

    前端开发应该都知道用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> 解决问题的方式,就是解决它一次

  • 相关阅读:
    Qt——QLineEdit使用总结
    qt中的lineEdit文本输入框的输入类型限制(三种验证类)
    qt 创建线程
    linux 安装和卸载软件
    c 结构体中的变长数组
    Qt之QSS(QDarkStyleSheet)
    Qt之QSS(Q_PROPERTY-原始属性)
    Qt之QSS(Q_PROPERTY-自定义属性)
    Qt之QSS(白色靓丽)
    Qt之QSS(样式表语法)
  • 原文地址:https://www.cnblogs.com/widgetbox/p/10756220.html
Copyright © 2011-2022 走看看