JQuery Cycle: 1 цикл, несколько пейджеров
Долгое время читатель, первый постер.:)
Я использую плагин jQuery Cycle, который можно скачать здесь: http://jquery.malsup.com/cycle/
У меня все работает нормально для почтовой части, но поступил запрос на управление пейджером выше и ниже объекта, который циклически повторяется.
Кажется, что второй пейджер не срабатывает, либо с выделением ссылки на пейджер активной панели и нажатием на второй элемент управления пейджером просто добавляется "#" к URL в адресной строке.
Я видел этот пост: stackru.com/questions/1663974/using-multiple-pagers-in-jquery-cycle-plugin
какой вид имеет смысл, но не уверен, почему он будет отличаться от моего, конечный результат моего можно увидеть здесь: http://dev02.web.lumens.demandware.net/on/demandware.store/Sites-Lumens-Site/default/Search-Show?cgid=brands, если вы прокрутите до конца.
HTML выглядит примерно так:
<ul class="pager"></ul>
<div id="list-screens" class="list-screens">
<div class="list-view-row"><!-- content goes here-></div>
</div>
<ul class="pager"></ul>
Для Javascript:
jQuery(document).ready(function() {
var markupBegin = '<li><a href="#">';
var markupEnd = "</a></li>";
var i = 0;
var pagerArray = ["A - E","F - J", "K - O","P - T","U - Z", "#"];
var detailPagerArray = ["A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z","${'#'}"];
jQuery("${'#'}list-screens").children().each(function(index, element) {
jQuery(".list-view .pager").append(markupBegin + pagerArray[i] + markupEnd);
//if(i <jQuery("${'#'}list-screens").children().length - 1 ) {
jQuery(".list-view .pager").append("<li class='divider'></li>");
//}
i++;
});
jQuery(".list-view .pager").append("<li><a href=\"#\">See All Brands</a>");
jQuery(".list-view .pager").append("<li class='clear'></li>");
// browse listview
jQuery("#list-screens").cycle({
fx: 'scrollLeft',
easing: 'linear',
timeout: 0,
speed: 750,
width:935,
height:500,
pager: ".list-view .pager",
pagerAnchorBuilder: function(idx, slide) {
// console.log(idx);
//for every amount its over 1 we have to add an extra to account for the divider li
if(idx == 0) { // shouldn't have to do anything
} else {
idx = idx + (idx);
}
return ".list-view .pager li:eq("+ idx +") a";
},
updateActivePagerLink : function(pager, currSlideIndex) {
if(currSlideIndex != 0) {
currSlideIndex = currSlideIndex + currSlideIndex;
}
jQuery(pager).find("li").removeClass("activeSlide").filter('li:eq('+currSlideIndex+')').addClass("activeSlide");
}
});
Я мог бы, вероятно, попытаться просто захватить щелчки и подключиться к событиям цикла и заставить его таким образом, но это кажется немного странным, что это не работает. Я заметил, что есть одна опция, позволяющая кликам по ссылке пузыриться. Не был уверен, что это то, что мне нужно. Спасибо за вашу помощь.
1 ответ
Вы всегда можете вернуться к ручному созданию пейджера и обработке кликов
пример можно найти здесь:
http://jquery.malsup.com/cycle/goto2.html
это создает 1 пейджер, но вы можете создать много, как это во втором buttonContainer
var bc = $('#buttonContainer');
var $container = $('#container').cycle({
fx: 'scrollHorz',
speed: 300,
timeout: 0
});
$container.children().each(function(i) {
// create input
$('<input type="button" value="'+(i+1)+'" />')
// append it to button container
.appendTo(bc)
// bind click handler
.click(function() {
// cycle to the corresponding slide
$container.cycle(i);
return false;
});
});