Использование jQuery для ограничения количества элементов списка
У меня есть элемент списка, содержащий ряд между 20-30 событий. Я хочу показать только 5 из них, и у меня есть Ссылка" Больше", которую я могу щелкнуть, чтобы посмотреть следующие пять. Неважно, если пять следующего события добавляются.
Не могу найти скрипт jQuery, который действительно это делает, или я просто слепой? Я не хочу использовать плагины carousel или что-то в этом роде.
5 ответов
ну, к счастью для нас программистов, которые пишут код для еды и славы, не все мыслимые функциональные возможности были написаны еще как плагин:)
но это довольно легко:
var from = 0, step = 5;
function showNext(list) {
list
.find('li').hide().end()
.find('li:lt(' + (from + step) + '):not(li:lt(' + from + '))')
.show();
from += step;
}
function showPrevious(list) {
from -= step;
list
.find('li').hide().end()
.find('li:lt(' + from + '):not(li:lt(' + (from - step) + '))')
.show();
}
// show initial set
showNext($('ul'));
// clicking on the 'more' link:
$('#more').click(function(e) {
e.preventDefault();
showNext($('ul'));
});
конечно, это лучше извлечь в плагин, как функция, но я собираюсь оставить это в качестве упражнения для читателя;)
<html>
<head><title>Test</title></head>
<body>
<ul class="more">
<li>one</li>
<li>two</li>
<li>three</li>
<li>four</li>
<li>five</li>
<li>six</li>
<li>seven</li>
<li>eight</li>
<li>nine</li>
<li>ten</li>
</ul>
<script type="text/javascript" src="jquery-1.3.1.js"></script>
<script type="text/javascript">
$(function() {
$("ul.more").each(function() {
$("li:gt(4)", this).hide(); /* :gt() is zero-indexed */
$("li:nth-child(5)", this).after("<li class='more'><a href='#'>More...</a></li>"); /* :nth-child() is one-indexed */
});
$("li.more a").live("click", function() {
var li = $(this).parents("li:first");
li.parent().children().show();
li.remove();
return false;
});
});
</script>
</script
</body>
</html>
в основном это делает:
- скрывает 6-й и последующие элементы списка;
- вставляет элемент списка после 5-го, говоря " больше...";
- использует live events для добавления обработчика событий в "More..."ссылки так, что при нажатии они показывают все элементы списка в этом списке, а затем удаляют себя.
Edit: Исправлено несколько небольших ошибок. Выше приведен полностью рабочий пример (просто убедитесь, что ссылка jquery верна).
вы хотите начать с каждого элемента в списке скрытых (CSS: display: none). Затем у вас есть еще ссылка undernearth элемент списка.
$(document).ready(function()
{
$("a#myMoreLink").click(function()
{
var items = $("ul#myList > li:hidden");
if(items.length > 0)
items.slice(0, 5).show();
else
$(this).html("No more");
return false;
});
$("a#myMoreLink").click();
});
в HTML:
<ul id="myList">
<li style="display: none"></li>
<li style="display: none"></li>
</ul>
<a href="http://" id="myMoreLink">More</a>
что-то подобное. $("a#myMoreLink").нажмите (); вызывается для отображения начальных 5 элементов при загрузке страницы.
это работает, но уверен, что вам придется настроить его немного чего :)
HTML-код:
<div style="width:200px;border:3px groove blue;">
<ul id="list">
<li>Thai</li>
<li>Turkish</li>
<li>Portuguese</li>
<li>American English</li>
<li>Arabic</li>
<li>Canadian French</li>
<li>Chinese Simplified</li>
<li>Chinese Traditional</li>
<li>Czech</li>
<li>Danish</li>
<li>Dutch</li>
<li>English</li>
<li>Finnish</li>
<li>French</li>
<li>German</li>
<li>Greek</li>
<li>Hebrew</li>
<li>Hungarian</li>
<li>Italian</li>
<li>Japanese</li>
<li>Norweigan</li>
<li>Polish</li>
<li>Russian</li>
<li>Spanish</li>
</ul>
<a href="#" id="lnkMore">More</a>
</div>
javascript:
<script type="text/javascript">
var len = 0;
var curStart = 0;
var count = 5;
var items=new Array();
function BackupList() {
var lst = $("ul#list");
len= $("ul#list li").length;
if (len <= count)
return;
$("ul#list li").each(function() {
items.push($(this));
$(this).remove();
});
var html="";
for (curStart; curStart < count && curStart < len; curStart++) {
html += "<li>" + $(items[curStart]).html() + "</li>";
}
$(html).appendTo($(lst));
}
function ShowMore() {
if (curStart >= len) {
curStart = 0;
}
$("ul#list li").each(function() {
$(this).remove();
});
var l = curStart;
var html = "";
for (curStart; curStart < (l + count) && curStart < len; curStart++) {
html += "<li>" + items[curStart].html() + "</li>";
}
$(html).appendTo($("ul#list"));
}
</script>
провод jquery для события:
<script type="text/javascript">
$(document).ready(function() {
BackupList();
$("a#lnkMore").click(function() { ShowMore(); });
});
</script>
Я написал плагин hideMaxListItems, который может быть тем, что вы искали. Вы можете установить максимальное количество элементов списка, скорость анимации для анимации слайдов и развернуть/свернуть кнопку HTML. Анимация слайдов выполняется последовательно для каждого элемента списка, чтобы обеспечить плавную анимацию.
http://www.joshuawinn.com/maximum-list-items-jquery-hide-after-x-number-bullets/