javascript超过容器后显示省略号效果(兼容一行或者多行)

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
 };

demo下载

注意:刚刚在浏览器兼容问题 发现一个bug IE9下不支持line-height属性 所以在IE9下一览时候,本来想显示2行 但是且显示了一行,在IE6-8都是正常的,这个bug等明天晚上来解决,今天晚上先不解决,要睡觉了哦!

javascript超过容器后显示省略号效果(兼容一行或者多行),布布扣,bubuko.com

时间: 2024-10-13 10:32:59

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

内容超过宽度后显示省略号

<div class="demo">让我们荡起双桨,小船儿推开波浪,海面倒映着美丽的白塔,四周环绕着绿树红墙!</div> <style> .demo{ width:50px; border:1px solid pink; white-space:nowrap; text-overflow:ellipsis; overflow: hidden; } </style> 显示如下:

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

样式: {width: 160px; overflow: hidden; text-overflow:ellipsis; white-space: nowrap;} 说明: white-space: nowrap 保证文本内容不会自动换行,如果多余的内容会在水平方向撑破单元格. overflow: hidden 隐藏超出单元格的部分. text-overflow: ellipsis 将被隐藏的那部分用省略号代替.

内容超过长度后以省略号显示

{width: 150px; overflow: hidden; text-overflow:ellipsis; white-space: nowrap;} 1.之前在考虑如果进行字符串截断时,一直在思考如何用js来完成而忽略了css的text-overflow属性: 通过设置white-space:nowrap使字符串不换行,然后设置text-overflow:ellipsis,显示省略标记(如果不想显示省略标记,将text-overflow设为clip): 2.缺点在于只能在只显示一行时使用

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

1.如果是单行文本: overflow: hidden; text-overflow: ellipsis; white-space: nowrap; 2.如果是多行文本,将文本框高度设为文字行高的倍数,然后在文本后建一个content为"..."的宽度为1em并设置文本背景色的after伪类,相对文本框设置绝对位置为下0右0:这样可以在视觉上实现同样的省略效果. 3.或者直接在文本框后新建一个元素,比如 这个右下角显示详情,并且是个链接,可以新建一个链接,然后绝对位置右0下0,记着设置

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

1 <style type="text/css"> 2 li { 3 width:200px;/*宽度,超过即会溢出*/ 4 line-height:25px;/*设置行间距*/ 5 text-overflow:ellipsis;/*当文本溢出时显示…此时还必须定义: 6 强制文本在一行内显示(white-space:nowrap)及溢出内容为隐藏 (overflow:hidden)*/ 7 white-space:nowrap;/*表示文本不会换行*/ 8 overflo

文字溢出显示省略号,兼容ie9以上浏览器

最近遇上一个问题,文字溢出展示省略号在ie上不管用,经过查找,是少了word-wrap: normal;这个css属性 width:100px; overflow: hidden; white-space: nowrap; word-wrap: normal;  text-overflow: ellipsis;

css使文字显示两行后显示省略号

本人喜欢把一些实用的东东拿过来,写成文章或者收藏起来.于是乎... 直接上代码: .article { color: #000000; overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; word-break: break-all; } 狠狠的点击,查看效果吧 原文地址:https://www.cnblogs.com/homehtml/p/12625871.htm

CSS控制文本超出指定宽度后用省略号代替,CSS控制文本不换行

CSS控制文本超出指定宽度后用省略号代替,CSS控制文本不换行. 一般的文字截断(适用于内联与块): .text-overflow {     display:block;/*内联对象需加*/     width:31em;     word-break:keep-all;/* 不换行 */     white-space:nowrap;/* 不换行 */     overflow:hidden;/* 内容超出宽度时隐藏超出部分的内容 */     text-overflow:ellipsis;

超过容器的文字显示为省略号

当文字的长度超过容器的边框时,若想要显示多余的内容为省略号时,我们可以这么设置 .truncate { width: 250px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } 注意到white-space与overflow的条件不可少.