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


Posted in Javascript onJuly 14, 2016

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超过容器后显示省略号效果的方法(兼容一行或者多行)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery最佳实践完整篇
Aug 20 Javascript
js确认删除对话框适用于a标签及submit
Jul 10 Javascript
jQuery插件animateSlide制作多点滑动幻灯片
Jun 11 Javascript
基于jQuery实现网页打印功能
Dec 01 Javascript
基于javascript实现最简单的选项卡切换效果
May 16 Javascript
WebSocket+node.js创建即时通信的Web聊天服务器
Aug 08 Javascript
AngularGauge 属性解析详解
Sep 06 Javascript
JavaScript实现事件的中断传播和行为阻止方法示例
Jan 20 Javascript
基于VUE选择上传图片并页面显示(图片可删除)
May 25 Javascript
Vue学习之路之登录注册实例代码
Jul 06 Javascript
ajax请求data遇到的问题分析
Jan 18 Javascript
手动用webpack搭建第一个ReactApp的示例
Apr 11 Javascript
AngularJS实用开发技巧(推荐)
Jul 13 #Javascript
JS中如何比较两个Json对象是否相等实例代码
Jul 13 #Javascript
js实现可键盘控制的简单抽奖程序
Jul 13 #Javascript
原生js仿jquery animate动画效果
Jul 13 #Javascript
瀑布流的实现方式(原生js+jquery+css3)
Jun 28 #Javascript
jquery计算出left和top,让一个div水平垂直居中的简单实例
Jul 13 #Javascript
Javascript类型系统之undefined和null浅析
Jul 13 #Javascript
You might like
PHP新手上路(十三)
2006/10/09 PHP
PHPMailer 中文使用说明小结
2010/01/22 PHP
实例讲解YII2中多表关联的使用方法
2017/07/21 PHP
php apache开启跨域模式过程详解
2019/07/08 PHP
PHP使用ajax的post方式下载excel文件简单示例
2019/08/06 PHP
js parsefloat parseint 转换函数
2010/01/21 Javascript
Javascript 修改String 对象 增加去除空格功能(示例代码)
2013/11/30 Javascript
JavaScript strike方法入门实例(给字符串加上删除线)
2014/10/17 Javascript
JavaScript限定图片显示大小的方法
2015/03/11 Javascript
javascript引用类型之时间Date和数组Array
2015/08/27 Javascript
BootStrap glyphicon图标无法显示的解决方法
2016/09/06 Javascript
JavaScript中boolean类型之三种情景实例代码
2016/11/21 Javascript
利用vscode编写vue的简单配置详解
2017/06/17 Javascript
AngularJS发送异步Get/Post请求方法
2018/08/13 Javascript
微信小程序之裁剪图片成圆形的实现代码
2018/10/11 Javascript
Layui Table js 模拟选中checkbox的例子
2019/09/03 Javascript
[04:28]DOTA2亚洲邀请赛小组赛第五日 TOP10精彩集锦
2015/02/03 DOTA
[54:27]TNC vs Serenity 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
简单的通用表达式求10乘阶示例
2014/03/03 Python
Python入门篇之编程习惯与特点
2014/10/17 Python
python利用标准库如何获取本地IP示例详解
2017/11/01 Python
Python实现字典的遍历与排序功能示例
2017/12/23 Python
python3 flask实现文件上传功能
2020/03/20 Python
在Python函数中输入任意数量参数的实例
2019/07/16 Python
python实现桌面托盘气泡提示
2019/07/29 Python
Django 在iframe里跳转顶层url的例子
2019/08/21 Python
python3.7 利用函数os pandas利用excel对文件名进行归类
2019/09/29 Python
python中的RSA加密与解密实例解析
2019/11/18 Python
pytorch实现线性拟合方式
2020/01/15 Python
python集成开发环境配置(pycharm)
2020/02/14 Python
VICHY薇姿英国官网:全球专业敏感肌护肤领先品牌
2017/07/04 全球购物
The Body Shop美体小铺西班牙官网:天然化妆品
2019/06/21 全球购物
董事长秘书岗位职责
2013/11/29 职场文书
运动会稿件100字
2014/02/21 职场文书
《闻一多先生的说和做》教学反思
2014/04/28 职场文书
《小蝌蚪找妈妈》教学反思
2016/02/23 职场文书