我有这样的代码:
<ul class="gallery_demo_unstyled">
<li class="active"><img src='001.jpg' /></li>
<li><img src='002.jpg' /></li>
<li><img src='003.jpg' /></li>
<li><img src='004.jpg' /></li>
<li><img src='005.jpg' /></li>
<li><img src='006.jpg' /></li>
</ul>
<div class="Paginator">
<a href="../2/" class="Prev"><<</a>
<a href="../1/">1</a>
<a href="../2/">2</a>
<span class="this-page">3</span>
<a href="../4/">4</a>
<a href="../5/">5</a>
<a href="../4/" class="Next">>></a>
</div>
<div class="Albums"><div class="AlbumsMenu">
<p><b>ALBUMS</b></p>
<p><a href="../../blackandwhite/1/" >blackandwhite</a></p>
<p><a href="../../color/1/" class='this-page'>>>color</a></p>
<p><a href="../../film/1/" >film</a></p>
<p><a href="../../digital/1/" >digital</a></p>
<p><a href="../../portraits/1/" >portraits</a></p>
</div></div>
...和一些JavaScript / jQuery允许循环遍历图像(最顶层的li元素)返回到最后一个图像之后的第一个图像:
$$.nextSelector = function(selector) {
return $(selector).is(':last-child') ?
$(selector).siblings(':first-child') :
$(selector).next();
};
当前页面始终是'this-page'类(在我的情况下为span或p,但如果需要,我可以更改)。
问题:我应该在代码中更改哪些内容以使其在最后一个图像之后转到下一页而不是一遍又一遍地遍历页面,并在最后一页之后转到下一张专辑?并且在倒数第一张专辑的第一页上的第一张图片(或者只是停在那里 - 不关心)?
答案 0 :(得分:4)
类似的东西:
function nextImage()
{
var li = $('#gallery_demo_unstyled li.active');
if (li.is(':last-child')) {
nextPage();
} else {
li.removeClass('active');
li.next().addClass('active');
}
}
function nextPage()
{
var next = $('div.Paginator a.Next');
if (next.length == 0) {
nextAlbum();
} else {
window.location = next.attr('href');
}
}
function nextAlbum()
{
var this_album = $('div.AlbumsMenu p a.this-name');
var p = this_album.parent();
if (p.next().length == 0) {
return;
}
window.location = p.next().children('a').attr('href');
}