久久久久在线观看_又色又爽又黄的免费视频播放_一区中文字幕_日韩电影在线播放

今日焦點 焦點資訊 營銷之道 企業報道 淘寶運營 網站建設 軟件開發 400電話
  當前位置: 首頁 » 資訊 » 軟件開發 » 正文

js實現超出文本變成省略號

放大字體  縮小字體 發布日期:2018-03-02  來源:企業800網  作者:新格網  瀏覽次數:190  【去百度看看】
核心提示:在實際的項目中,由于文字內容的長度不確定性和頁面布局的固定性,難免會出現文字內容超過p(或其他標簽,下同)區域的情況,此時比較好的做法就是當文字超過限定的p寬度后自動以省略號(…)顯示,這樣,按照習慣,人們都會知道這兒有文字被省略了。css中有個屬性叫做text-overflow:ellipsis;比如使用css可以這樣寫:
在實際的項目中,由于文字內容的長度不確定性和頁面布局的固定性,難免會出現文字內容超過p(或其他標簽,下同)區域的情況,此時比較好的做法就是當文字超過限定的p寬度后自動以省略號(…)顯示,這樣,按照習慣,人們都會知道這兒有文字被省略了。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所有的代碼如下:

 
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);
 
  },
 
  
 
  _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);
 
    }
 
  },
 
  
 
  getText: function(){
 
    var self = this,
 
      cfg = self.options;
 
    return $.trim($($(cfg.targetCls + "")[0]).html());
 
  },
 
  
 
  setText: function(text){
 
    var self = this,
 
      cfg = self.options;
 
    $($(cfg.targetCls + "")[0]).html(text);
 
  },
 
  
 
  _compareHeight: function(maxLineHeight) {
 
    var self = this;
 
    var curHeight = self._getTargetHeight();
 
    if(curHeight > maxLineHeight) {
 
      self._deleteText(self.getText());
 
    }
 
  },
 
  
 
  _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);
 
  },
 
  
 
  _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
 
};

相關推薦:

CSS限制顯示字數超出部分用省略號表示

標題文本溢出顯示省略號‘......’的方法

html文本控制顯示字數超出用省略號的方法

以上就是js實現超出文本變成省略號的詳細內容,更多請關注php中文網其它相關文章!

 
 
[ 資訊搜索 ]  [ 加入收藏 ]  [ 告訴好友 ]  [ 打印本文 ]  [ 違規舉報 ]  [ 關閉窗口 ]

 
0條 [查看全部]  相關評論

 
網站首頁 | 關于我們 | 聯系方式 | 使用協議 | 版權隱私 | 網站地圖 | 排名推廣 | 廣告服務 | 積分換禮 | 網站留言 | RSS訂閱 | 皖ICP備2021004516號-14
企業800網 · 提供技術支持