我正在使用jCarousel插件来显示一系列项目。 我正在按照网站上的此示例获取外部控件和分页控件。
这种方法有两个问题:
-
我需要手动为数字添加项目(而不仅仅是使用 JS 计算轮播中的项目数量),尽管我可以接受这一点,并且
-
似乎没有办法突出显示(通过类更改)当前幻灯片的项目
我正在做的是使用项目符号作为分页点,正如你在这个小提琴中看到的那样
<div class="carousel-nav cf">
<table>
<tr>
<td><a href="#" id="mycarousel-prev">◀</a></td>
<td>
<div class="jcarousel-control">
<a href="#">•</a>
<a href="#">•</a>
<a href="#">•</a>
</div>
</td>
<td><a href="#" id="mycarousel-next">►</a></td>
</tr>
</table>
</div>
并希望将当前项目的类设置为"活动"或类似。
有什么想法吗? 或者有更好的插件吗?我尝试了循环,但我需要两个同时显示 2 个或更多项目。谢谢。
html:
<ul class="jcarousel-control"></ul>
脚本:
$('.jcarousel-control')
.on('jcarouselpagination:active', 'li', function() {
$(this).addClass('active');
})
.on('jcarouselpagination:inactive', 'li', function() {
$(this).removeClass('active');
})
.jcarouselPagination({
'perPage':1,
'item': function(page, carouselItems) {
return '<li class="' + (page == 1 ? "active" : "") + '"><a href="#' + page + '"></a></li>';
}
});
$('.mycarousel-prev').jcarouselControl({target:'-=1'});
$('.mycarousel-next').jcarouselControl({target:'+=1'});
实际上您可以使用回调函数进行与当前活动轮播元素相关的高光
function highlighttab1(carousel, state, liindex) {
document.getElementById(liindex).className = "selected";}
function removehighlighttab1(carousel, state, liindex) {
document.getElementById(liindex).className = "unselected";}
几天前,我与 Jcarousel 合作,其中我有菜单标签面板(因为您有点)和所有静态超链接,单击这些超链接时将滚动到预期的轮播元素