javascript超过容器后显示省略号效果

      在实际的项目中,由于文字内容的长度不确定性和页面布局的固定性,难免会出现文字内容超过div(或其他标签,下同)区域的情况,此时比较好的做法就是当文字超过限定的div宽度后自动以省略号(…)显示,这样,按照习惯,人们都会知道这儿有文字被省略了。css中有个属性叫做text-overflow:ellipsis;比如使用css可以这样写:

{width:27em; white-space:nowrap; text-overflow:ellipsis; -o-text-overflow:ellipsis; overflow:hidden;}仅在Firefox火狐浏览器下无法实现文字溢出省略号表示,其文字直接从中间咔掉了,我这边不讲用css怎么样来实现这样的,具体的css实现可以自己百度去,我这边最主要的是讲怎么样用JS来实现,怎么样通过JS写一个简单的组件,我直接调用JS的初始化方法就可以实现掉!比如如下效果:

后面的点点点 来提示用户有更多的内容未显示完成这样的效果!

先废话少说!首先来看看我做的demo效果,就能明白到底是个什么样的效果!

想看效果,请点击我!ok?

一: 先来看看组件的配置项:如下:

   targetCls

null,    目标要截取的容器 必填项 默认为null

limitLineNumber 1,     要显示的行数 默认为1行

type '...',      超过了容器长度 显示的type 默认为省略号

lineHeight  18,       dom节点的行高 默认行高为18

isShowTitle true ,      title 是否需要title来显示所有的内容 默认为true

isCharLimit false     根据字符的长度来限制 超过显示省略号

maxLength 20        默认长度为20 超过字符20后 显示省略号

二:分析

1.  首先来讲讲此组件:支持2种方式来截取字符串,第一:根据字符的长度来截取,超过后显示省略号,比如我这样调用:

 

  new MultiEllipsis({

"targetCls" : '.text8',

"isCharLimit":true,

"maxLength": 18

  });

这样初始化的意思是说,isCharLimit为true是指用字符的个数来截取,最大的长度maxLength为18,这样初始化,因为代码里面会首先判断如果isCharLimit为true的话,就直接按照字符的个数来截取,比如如下代码:

2. 第二种是根据多少行数及高度来截取的,比如默认配置项的行高是18,如果我想显示2行,那也就是说高度h = 18*2, 假如容器的高度是100,那么截取的方法是:

  使用 (100 - type的长度 - 1)  是否大于 18×2,如果大于的话,继续截取,否则的不截取,且显示省略号效果!如下代码:

缺点:但是使用行高截取的话,如果数据比较少的话,是可以的,但是如果数据很多的话,比如高度为500像素或者更多的话,那么相对来说会影响性能的,因为他们每次都要计算n次(n为循环调用函数多的意思)。

JS所有的代码如下:

复制代码

/*

* 基于JS的MultiEllipsis

* @author tugenhua

*/

function MultiEllipsis(options) {

    var self = this;

    self.options = $.extend({},defaults,options || {});

    self._init();

}

$.extend(MultiEllipsis.prototype,{

     // 页面初始化

    _init: function(){

        var self = this,

            cfg = self.options;

        if(cfg.targetCls == null || $(cfg.targetCls + "")[0] === undefined) {

            if(window.console) {

                console.log("targetCls不为空!");

            }

            return;

        }

        if(cfg.isShowTitle) {

            // 获取元素的文本 添加title属性

            var title = self.getText();

            $(cfg.targetCls ).attr({"title":title});

        }

        // 如果是按照字符来限制的话 那么就不按照高度来比较 直接返回

        if(cfg.isCharLimit) {

            self._charCompare();

            return;

        }

        self._compareHeight(cfg.lineHeight * cfg.limitLineNumber);

    },

    /*

     * 按照字符的长度来比较 来显示文本

     * @method _charCompare {private}

     * @return  返回新的字符串到容器里面

     */

    _charCompare: function(){

        var self = this,

            cfg = self.options;

        var text = self.getText();

        if(text.length > cfg.maxLength) {

            var curText = text.substring(0,cfg.maxLength);

            $($(cfg.targetCls + "")[0]).html(curText  + cfg.type);

        }

    },

    /*

     * 获取目标元素的text

     * 如果有属性 data-text 有值的话 那么先获取这个值 否则的话 直接去html内容

     * @method getText {public}

     */

    getText: function(){

        var self = this,

            cfg = self.options;

        return $.trim($($(cfg.targetCls + "")[0]).html());

    },

    /*

     * 设置dom元素文本

     * @method setText {public}

     */

    setText: function(text){

        var self = this,

            cfg = self.options;

        $($(cfg.targetCls + "")[0]).html(text);

    },

    /*

     * 通过配置项的 行数 * 一行的行高  是否大于或者等于当前的高度

     * @method _compareHeight {private}

     */

    _compareHeight: function(maxLineHeight) {

        var self = this;

        var curHeight = self._getTargetHeight();

        if(curHeight > maxLineHeight) {

            self._deleteText(self.getText());

        }

    },

    /*

     * 截取文本

     * @method _deleteText {private}

     * @return 返回被截取的文本

     */

    _deleteText: function(text){

        var self = this,

            cfg = self.options,

            typeLen = cfg.type.length;

        var curText = text.substring(0,text.length - typeLen - 1);

        curText += cfg.type;

        // 设置元素的文本

        self.setText(curText);

        // 继续调用函数进行比较

        self._compareHeight(cfg.lineHeight * cfg.limitLineNumber);

    },

    /*

     * 返回当前dom的高度

     */

    _getTargetHeight: function(){

        var self = this,

            cfg = self.options;

        return $($(cfg.targetCls + "")[0]).height();

    }

});

var defaults = {

    'targetCls'               :     null,                 // 目标要截取的容器

    'limitLineNumber'         :     1,                     // 限制的行数 通过 行数 * 一行的行高 >= 容器的高度

    'type'                    :     '...',                 // 超过了长度 显示的type 默认为省略号

    'lineHeight'              :     18,                  // dom节点的行高 

    'isShowTitle'             :        true,                // title是否显示所有的内容 默认为true

    'isCharLimit'             :     false,               // 根据字符的长度来限制 超过显示省略号

    'maxLength'               :     20                   // 默认为20

};

javascript超过容器后显示省略号效果(兼容一行或者多行)的更多相关文章

  1. CSS3 文本超出后显示省略号...

    纯用CSS实现,主要采用代码 overflow:hidden; text-overflow:ellipsis;//这是让文本溢出后,显示成省略号. white-space:nowrap;//禁止自动换 ...

  2. css强制换行显示省略号之显示两行后显示省略号

    1,首先来一个固定宽度,在一行显示,超出隐藏,显示省略号的样式 display:block; white-space:nowrap; overflow:hidden; text-overflow:el ...

  3. CSS实现内容超过长度后以省略号显示

    样式: {width: 160px; overflow: hidden; text-overflow:ellipsis; white-space: nowrap;} 说明: white-space: ...

  4. TextView 设置超过几行后显示省略号

    android:lines="5" android:ellipsize="end"

  5. js判断超过几个字符后显示省略号

  6. css-文本超出后显示省略号

    1.如果是单行文本: overflow: hidden; text-overflow: ellipsis; white-space: nowrap; 2.如果是多行文本,将文本框高度设为文字行高的倍数 ...

  7. css设置内容超出后显示省略号

    1.使用overflow: hidden把超出的内容进行隐藏: 2.然后使用white-space: nowrap设置内容不换行: 3.最后使用text-overflow: ellipsis设置超出内 ...

  8. CSS实现文本超过指定长度显示省略号

    <style type="text/css"> li { width:200px;/*宽度,超过即会溢出*/ line-height:25px;/*设置行间距*/ te ...

  9. Css 设置超过再两行显示省略号

    大部分场景都是超过一行就显示... <template> <div class="other-product-item item-name" :title=&qu ...

随机推荐

  1. 解读ASP.NET 5 & MVC6系列(5):Configuration配置信息管理

    在前面的章节中,我们知道新版的MVC程序抛弃了原来的web.config文件机制,取而代替的是config.json,今天我们就来深入研究一下配置文件的相关内容. 基本用法 新版的配置信息机制在Mic ...

  2. TaintDroid剖析之File & Memiry & Socket级污点传播

    TaintDroid剖析之File & Memiry & Socket级污点传播 作者:简行.走位@阿里聚安全 1.涉及到的代码文件 TaintDroid在File, Memory以及 ...

  3. [搜索引擎]Sphinx的介绍和原理探索

    What/Sphinx是什么 定义 Sphinx是一个全文检索引擎. 特性 索引和性能优异 易于集成SQL和XML数据源,并可使用SphinxAPI.SphinxQL或者SphinxSE搜索接口 易于 ...

  4. CSharpGL(6)在OpenGL中绘制UI元素

    CSharpGL(6)在OpenGL中绘制UI元素 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码中包含10多个独立的Demo,更适合入 ...

  5. Html5 实现灯笼绘制

    最近在学习Html5,就用JavaScript在Canvas试着绘制了一个灯笼,并作了简要的说明. 具体绘制思路在页面上有说明,不再赘述,代码如下: <script type="tex ...

  6. Android 6.0 权限申请辅助 ----PermissionsHelper

    Android 6.0 权限申请辅助 ----PermissionsHelper 项目地址:https://github.com/didikee/PermissionsHelper Android 的 ...

  7. java即时通信小例子

    学习java一段时间了,今天写来一个即时通信的小例子练手在其过程中也学到了一些知识拿出来和大家分享,请路过的各位大神多多赐教... 好了下面讲一下基本的思路: 首先,编写服务器端的程序,简单点说吧就是 ...

  8. AngularJS 源码分析2

    上一篇地址 本文主要分析RootScopeProvider和ParseProvider RootScopeProvider简介 今天这个rootscope可是angularjs里面比较活跃的一个pro ...

  9. Linux更改用户密码

    登录虚拟机后,使用passwd密令更改用户密码,新密码需要输入两次才能更改成功.不多说,直接上代码 [root@localhost Desktop]# passwd //使用passwd密令 Chan ...

  10. SVM算法

    本文主要介绍支持向量机理论推导及其工程应用. 1 基本介绍 支持向量机算法是一个有效的分类算法,可用于分类.回归等任务,在传统的机器学习任务中,通过人工构造.选择特征,然后使用支持向量机作为训练器,可 ...