用于缩短长段落的jQuery插件

时间:2012-06-28 16:15:09

标签: jquery jquery-plugins

我有一个网站有很长的段落,我正在寻找一种方法来缩短初始演示文稿,所以我想要一个插件,让我可以选择扩展/收缩文本。

我已经找到类似的东西,如:http://jtsnake.github.com/jquery-readmore/但它没有做回滚功能。

我可以使用类似的东西吗?谢谢大家。

2 个答案:

答案 0 :(得分:1)

您可以使用相同的插件执行此操作。从您下载的插件zip文件中打开jquery.readmore.js。并从链接功能中删除以下代码行。

$(this).hide();

现在功能将是:

function linkage(elem) {
      elem.append(opts.more_link);
      elem.find('.' + opts.more_clzz).click( function () {
       elem.find('.' + opts.ellipse_clzz).hide();
        elem.find('.' + opts.hidden_clzz).animate({'opacity' : 'toggle'},1000);
      });
    }

首次点击它会显示有限的字符,然后再次缩短。您可以做的另一件事是缩短阅读更多文字:

more_link: '<a class="readm-more">Read&nbsp;More/Shorten</a>

P.S:如果你想要我会尝试将文字从更多内容更改为缩短点击次数,反之亦然。

答案 1 :(得分:1)

我实际上从来没有为这种动作制作插件,所以我决定给它一个镜头,这是我想出的 - &gt;

function($){
  $.fn.clipped = function(options){ 
    var settings = $.extend({
      'text' : this.text(),
      'start' : 0,
      'end' : 255,
      'showFrom': 255,
      'readMoreText': 'Read More',
      'readLessText': 'Read Less'     
    }, options);

  return this.each(function(){
    var $this = $(this);
        var origTxt = settings.text;
    var clippedTxt = origTxt.slice(settings.start, settings.end) + "<div class='read-hidden' style='display:none;opacity:0;'>" + $this.text().slice(settings.showFrom) +"</div><span class='read-clipped'>....<a href='#' class='read-click'>"+settings.readMoreText+"</a></span>";
    $this.html(clippedTxt);

    $('body').on('click', 'a.read-click', function(){
      if($('.read-hidden').css('display') == 'none'){
            //true returned, make changes as necessary.
        $('.read-clipped a').text(settings.readLessText).appendTo($(this).parent('p'));

        //display the rest of the text        
        $('.read-hidden').css('display', 'inline');
        $('.read-hidden').animate({
          opacity:1
        }, 500); 
          //element is shown already, replace the text on next click.  
      }else if($('.read-hidden').css('display') == 'inline'){
        $('.read-hidden').animate({
          opacity:0  
        }, 500, function(){
          $('.read-hidden').css('display', 'none');
          $this.html(clippedText);      
        });
       }
     });
   });
  }
})(jQuery);

调用插件非常简单 - &gt;

$('#element').clipped({ 
  // clip text at
  'start': 0, 
  //end clipped text at
  'end': 255, 
  //display the rest of the text starting from
  'showFrom': 255, 
  //Read More Text
  'readMoreText' : 'Read More Stuff',
  //Read Less Text 
  'readLessText' : 'Read Less Stuff'
 });