欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript超過容器后顯示省略號效果的方法(兼容一行或者多行)

 更新時間:2016年07月14日 09:10:01   投稿:jingxian  
下面小編就為大家?guī)硪黄猨avascript超過容器后顯示省略號效果的方法(兼容一行或者多行)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

javascript超過容器后顯示省略號效果

在實際的項目中,由于文字內(nèi)容的長度不確定性和頁面布局的固定性,難免會出現(xiàn)文字內(nèi)容超過div(或其他標簽,下同)區(qū)域的情況,此時比較好的做法就是當文字超過限定的div寬度后自動以省略號(…)顯示,這樣,按照習慣,人們都會知道這兒有文字被省略了。css中有個屬性叫做text-overflow:ellipsis;比如使用css可以這樣寫:

{width:27em; white-space:nowrap; text-overflow:ellipsis; -o-text-overflow:ellipsis; overflow:hidden;}僅在Firefox火狐瀏覽器下無法實現(xiàn)文字溢出省略號表示,其文字直接從中間咔掉了,我這邊不講用css怎么樣來實現(xiàn)這樣的,具體的css實現(xiàn)可以自己百度去,我這邊最主要的是講怎么樣用JS來實現(xiàn),怎么樣通過JS寫一個簡單的組件,我直接調(diào)用JS的初始化方法就可以實現(xiàn)掉!比如如下效果:

后面的點點點 來提示用戶有更多的內(nèi)容未顯示完成這樣的效果!

先廢話少說!首先來看看我做的demo效果,就能明白到底是個什么樣的效果!

想看效果,請點擊我!ok?

一: 先來看看組件的配置項:如下:

targetCls

null,    目標要截取的容器 必填項 默認為null

limitLineNumber 1,     要顯示的行數(shù) 默認為1行

type '...',      超過了容器長度 顯示的type 默認為省略號

lineHeight  18,       dom節(jié)點的行高 默認行高為18

isShowTitle true ,      title 是否需要title來顯示所有的內(nèi)容 默認為true

isCharLimit false     根據(jù)字符的長度來限制 超過顯示省略號

maxLength 20        默認長度為20 超過字符20后 顯示省略號

二:分析

1.  首先來講講此組件:支持2種方式來截取字符串,第一:根據(jù)字符的長度來截取,超過后顯示省略號,比如我這樣調(diào)用:

new MultiEllipsis({
"targetCls" : '.text8',
"isCharLimit":true,
"maxLength": 18

  });

這樣初始化的意思是說,isCharLimit為true是指用字符的個數(shù)來截取,最大的長度maxLength為18,這樣初始化,因為代碼里面會首先判斷如果isCharLimit為true的話,就直接按照字符的個數(shù)來截取,比如如下代碼:

2. 第二種是根據(jù)多少行數(shù)及高度來截取的,比如默認配置項的行高是18,如果我想顯示2行,那也就是說高度h = 18*2, 假如容器的高度是100,那么截取的方法是:

使用 (100 - type的長度 - 1)  是否大于 18×2,如果大于的話,繼續(xù)截取,否則的不截取,且顯示省略號效果!如下代碼:

缺點:但是使用行高截取的話,如果數(shù)據(jù)比較少的話,是可以的,但是如果數(shù)據(jù)很多的話,比如高度為500像素或者更多的話,那么相對來說會影響性能的,因為他們每次都要計算n次(n為循環(huán)調(diào)用函數(shù)多的意思)。

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內(nèi)容 

   * @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); 

  }, 

  /* 

   * 通過配置項的 行數(shù) * 一行的行高 是否大于或者等于當前的高度 

   * @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); 

    // 繼續(xù)調(diào)用函數(shù)進行比較 

    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,           // 限制的行數(shù) 通過 行數(shù) * 一行的行高 >= 容器的高度 

  'type'          :   '...',         // 超過了長度 顯示的type 默認為省略號 

  'lineHeight'       :   18,         // dom節(jié)點的行高 

  'isShowTitle'       :    true,        // title是否顯示所有的內(nèi)容 默認為true 

  'isCharLimit'       :   false,        // 根據(jù)字符的長度來限制 超過顯示省略號 

  'maxLength'        :   20          // 默認為20 

}; 

以上這篇javascript超過容器后顯示省略號效果的方法(兼容一行或者多行)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

  • JavaScript實現(xiàn)窗口抖動效果

    JavaScript實現(xiàn)窗口抖動效果

    抖動效果在各大網(wǎng)頁上都常遇到,這篇文章主要介紹了JavaScript實現(xiàn)窗口抖動效果的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-10-10
  • Bootstrap面板學習使用

    Bootstrap面板學習使用

    這篇文章主要為大家詳細介紹了Bootstrap面板的學習使用,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • javascript適配器模式和組合模式原理與實現(xiàn)方法詳解

    javascript適配器模式和組合模式原理與實現(xiàn)方法詳解

    這篇文章主要介紹了javascript適配器模式和組合模式原理與實現(xiàn)方法,結合實例形式詳細分析了javascript適配器模式與組合模式相關原理、功能、實現(xiàn)方法與注意事項,需要的朋友可以參考下
    2023-07-07
  • js給onclick事件賦值,動態(tài)傳參數(shù)實例解說

    js給onclick事件賦值,動態(tài)傳參數(shù)實例解說

    js動態(tài)給對象onclick事件賦值,動態(tài)傳參數(shù)舉兩個例子一對一錯,感興趣的朋友可以對比下,希望可以從中發(fā)現(xiàn)不一樣之處
    2013-03-03
  • JavaScript實現(xiàn)對下拉列表值進行排序的方法

    JavaScript實現(xiàn)對下拉列表值進行排序的方法

    這篇文章主要介紹了JavaScript實現(xiàn)對下拉列表值進行排序的方法,實例分析了javascript對下拉列表元素的遍歷與排序?qū)崿F(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07
  • Bootstrap實現(xiàn)默認導航欄效果

    Bootstrap實現(xiàn)默認導航欄效果

    這篇文章主要介紹了Bootstrap實現(xiàn)默認導航欄效果,導航欄是一個很好的功能,是Bootstrap網(wǎng)站的一個突出特點,本文帶領大家學習實現(xiàn)Bootstrap導航欄,需要的朋友可以參考下
    2015-12-12
  • javascript閉包的高級使用方法實例

    javascript閉包的高級使用方法實例

    這篇文章介紹了javascript閉包的高級使用方法實例,有需要的朋友可以參考一下
    2013-07-07
  • JavaScript實現(xiàn)在頁面間傳值的方法

    JavaScript實現(xiàn)在頁面間傳值的方法

    這篇文章主要介紹了JavaScript實現(xiàn)在頁面間傳值的方法,涉及javascript傳值的技巧,非常具有實用價值,需要的朋友可以參考下
    2015-04-04
  • 最新評論