我正在使用插件Tiny Carousel(http://baijs.nl/tinycarousel),但我无法找到让多个实例在单个页面上工作的方法 - 该网站似乎缺少此文档。
我在服务器上有我的例子。如您所见,只有第一个实例正在运行:http://irishhuddle.com/RSS/slider/slidertest.html。
如何修改我的HTML和.js文件以使其工作?我知道有类似的问题被问过......我花了很多时间阅读它们,但找不到将相同的原则应用到我的代码中的方法。
我的js文件:
(function($){
$.tiny = $.tiny || { };
$.tiny.carousel = {
options: {
start: 1, // where should the carousel start?
display: 1, // how many blocks do you want to move at 1 time?
axis: 'x', // vertical or horizontal scroller? ( x || y ).
controls: true, // show left and right navigation buttons.
pager: false, // is there a page number navigation present?
interval: false, // move to another block on intervals.
animation: true, // false is instant, true is animate.
duration: 500, // how fast must the animation move in ms?
callback: null // function that executes after every move.
}
};
$.fn.tinycarousel = function(options) {
var options = $.extend({}, $.tiny.carousel.options, options);
this.each(function(){ $(this).data('tcl', new Carousel($(this), options)); });
return this;
};
$.fn.tinycarousel_move = function(iNum){ $(this).data('tcl').move(iNum-1,true); };
function Carousel(root, options){
var oSelf = this;
var oViewport = $('.viewport:first', root);
var oContent = $('.overview:first', root);
var oPages = oContent.children();
var oBtnNext = $('.next:first', root);
var oBtnPrev = $('.prev:first', root);
var oPager = $('.pager:first', root);
var iPageSize, iSteps, iCurrent, oTimer, bPause, bForward = true, bAxis = options.axis == 'x';
function initialize(){
iPageSize = bAxis ? $(oPages[0]).outerWidth(true) : $(oPages[0]).outerHeight(true);
var iLeftover = Math.ceil(((bAxis ? oViewport.outerWidth() : oViewport.outerHeight()) / (iPageSize * options.display)) -1);
iSteps = Math.max(1, Math.ceil(oPages.length / options.display) - iLeftover);
iCurrent = Math.min(iSteps, Math.max(1, options.start)) -2;
oContent.css(bAxis ? 'width' : 'height', (iPageSize * oPages.length));
oSelf.move(1);
setEvents();
return oSelf;
};
function setEvents(){
if(options.controls && oBtnPrev.length > 0 && oBtnNext.length > 0){
oBtnPrev.click(function(){oSelf.move(-1); return false;});
oBtnNext.click(function(){oSelf.move( 1); return false;});
}
if(options.interval){ root.hover(oSelf.stop,oSelf.start); }
if(options.pager && oPager.length > 0){ $('a',oPager).click(setPager); }
};
function setButtons(){
if(options.controls){
oBtnPrev.toggleClass('disable', !(iCurrent > 0));
oBtnNext.toggleClass('disable', !(iCurrent +1 < iSteps));
}
if(options.pager){
var oNumbers = $('.pagenum', oPager);
oNumbers.removeClass('active');
$(oNumbers[iCurrent]).addClass('active');
document.getElementById('slidenum').innerHTML = iCurrent+1;
}
};
this.move = function(iDirection, bPublic){
iCurrent = bPublic ? iDirection : iCurrent += iDirection;
if(iCurrent > -1 && iCurrent < iSteps){
var oPosition = {};
oPosition[bAxis ? 'left' : 'top'] = -(iCurrent * (iPageSize * options.display));
oContent.animate(oPosition,{
queue: false,
duration: options.animation ? options.duration : 0,
complete: function(){
if(typeof options.callback == 'function')
options.callback.call(this, oPages[iCurrent], iCurrent);
}
});
setButtons();
}
};
return initialize();
};
})(jQuery);
更新:我的HTML现在看起来像这样:
<script type="text/javascript">
$(document).ready(function(){
$('#slider-code').tinycarousel({ pager: true });
$('#slider-code2').tinycarousel({ pager: true });
});
</script>
<div id="slider-code">
<div class="viewport">
<ul class="overview">
<li><a rel="1" class="pagenum" href="#">Hi 1</a></li>
<li><a rel="2" class="pagenum" href="#">Hi 2</a></li>
<li><a rel="3" class="pagenum" href="#">Hi 3</a></li>
<li><a rel="4" class="pagenum" href="#">Hi 4</a></li>
<li><a rel="5" class="pagenum" href="#">Hi 5</a></li>
<li><a rel="6" class="pagenum" href="#">Hi 6</a></li>
</ul>
</div>
<ul class="pager">
<li><a href="#" class="buttons prev">left</a></li>
<li id="slidenum">1</li><li> / 6</li>
<li><a href="#" class="buttons next">right</a></li>
</ul>
</div>
<div id="slider-code2">
<div class="viewport">
<ul class="overview">
<li><a rel="1" class="pagenum" href="#">Hi 1</a></li>
<li><a rel="2" class="pagenum" href="#">Hi 2</a></li>
<li><a rel="3" class="pagenum" href="#">Hi 3</a></li>
<li><a rel="4" class="pagenum" href="#">Hi 4</a></li>
<li><a rel="5" class="pagenum" href="#">Hi 5</a></li>
<li><a rel="6" class="pagenum" href="#">Hi 6</a></li>
</ul>
</div>
<ul class="pager">
<li><a href="#" class="buttons prev">left</a></li>
<li id="slidenum">1</li><li> / 6</li>
<li><a href="#" class="buttons next">right</a></li>
</ul>
</div>
答案 0 :(得分:0)
您只需在另一个滑块上调用$('#slider1').tinycarousel();
在您的情况下,例如:$('#slider-code').tinycarousel();
和$('#slider-code2').tinycarousel();
应该全部
修改强>
只需快速修复您的HTML:
<div id="slider-code">
<div class="viewport">
<ul class="overview">
<li><a rel="1" class="pagenum" href="#">Hi 1</a></li>
<li><a rel="2" class="pagenum" href="#">Hi 2</a></li>
<li><a rel="3" class="pagenum" href="#">Hi 3</a></li>
<li><a rel="4" class="pagenum" href="#">Hi 4</a></li>
<li><a rel="5" class="pagenum" href="#">Hi 5</a></li>
<li><a rel="6" class="pagenum" href="#">Hi 6</a></li>
</ul>
</div>
<ul class="pager">
<li><a href="#" class="buttons prev">left</a></li>
<li id="slidenum">1</li><li> / 6</li>
<li><a href="#" class="buttons next">right</a></li>
</ul>
</div>
<div id="slider-code2">
<div class="viewport">
<ul class="overview">
<li><a rel="1" class="pagenum" href="#">Hi 1</a></li>
<li><a rel="2" class="pagenum" href="#">Hi 2</a></li>
<li><a rel="3" class="pagenum" href="#">Hi 3</a></li>
<li><a rel="4" class="pagenum" href="#">Hi 4</a></li>
<li><a rel="5" class="pagenum" href="#">Hi 5</a></li>
<li><a rel="6" class="pagenum" href="#">Hi 6</a></li>
</ul>
</div>
<ul class="pager">
<li><a href="#" class="buttons prev">left</a></li>
<li id="slidenum">1</li><li> / 6</li>
<li><a href="#" class="buttons next">right</a></li>
</ul>
</div>
答案 1 :(得分:0)
我通过将#slider-code
转换为HTML类.slider-code
来解决我的问题。将该更改应用于CSS和调用方函数。然后将所有实例命名为.slider-code
。