我有一个网站有很长的段落,我正在寻找一种方法来缩短初始演示文稿,所以我想要一个插件,让我可以选择扩展/收缩文本。
我已经找到类似的东西,如:http://jtsnake.github.com/jquery-readmore/但它没有做回滚功能。
我可以使用类似的东西吗?谢谢大家。
答案 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 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'
});