我已创建此滑块代码...
试图获得第一张和最后一张幻灯片,使下一个和上一个按钮处于活动状态或者禁用... ...任何人都可以帮助我获取它...
$(document).ready(function(){
$('.myslider-wrapper').each(function(){
// thumbSlide
var countSlider = $('.thumbSlide', this).length;
if((".thumbSlide").length){
// Declare variables
var totalImages = $(".thumbSlide > li", this).length,
imageWidth = $(".thumbSlide > li:first", this).outerWidth(true),
totalWidth = imageWidth * totalImages,
visibleImages = Math.round($(".thumbSlide-wrap", this).width() / imageWidth),
visibleWidth = visibleImages * imageWidth,
stopPosition = (visibleWidth - totalWidth/countSlider);
$(".thumbSlide", this).width(totalWidth+10);
}
$(".thumbSlide-prev", this).click(function(){
var parentMove = $(this).parent().prev('.thumbSlide');
if(parentMove.position().left < 0 && !$(".thumbSlide").is(":animated")){
parentMove.animate({left : "+=" + imageWidth + "px"});
}
return false;
});
$(".thumbSlide-next", this).click(function(){
var parentMove = $(this).parent().prev('.thumbSlide');
if(parentMove.position().left > stopPosition && !$(".thumbSlide").is(":animated")){
parentMove.animate({left : "-=" + imageWidth + "px"});
}
return false;
});
});
});
jsfiddle:http://jsfiddle.net/GLSqS/1/
非常感谢..答案 0 :(得分:2)
你可以这样做,而不是每个幻灯片的下一个和上一个使用id的类隐藏那个特定的一个而不是全部,我留给你,
我对此代码进行了一些更改,以显示和隐藏,下一个和上一个按钮:
if($('.thumbSlide li:first')){
$('.thumbSlide-prev').hide();
}
$(".thumbSlide-prev", this).click(function(){
var parentMove = $(this).parent().prev('.thumbSlide');
$(".thumbSlide-next").show();
if(parentMove.position().left < 0 && !$(".thumbSlide").is(":animated")){
parentMove.animate({left : "+=" + imageWidth + "px"});
}else{
$('.thumbSlide-prev').hide();
}
return false;
});
$(".thumbSlide-next", this).click(function(){
var parentMove = $(this).parent().prev('.thumbSlide');
//var parent=$(this).parent();
$(".thumbSlide-prev").show();
if(parentMove.position().left > stopPosition && !$(".thumbSlide").is(":animated")){
parentMove.animate({left : "-=" + imageWidth + "px"});
}else{
$(".thumbSlide-next").hide();
}
return false;
});
演示Fiddle
答案 1 :(得分:1)
我稍微修改了你的代码。试试下面的小提琴。
$(document).ready(function(){
$('.myslider-wrapper').each(function(){
// thumbSlide
var countSlider = $('.thumbSlide', this).length;
if((".thumbSlide").length){
// Declare variables
var totalImages = $(".thumbSlide > li", this).length,
imageWidth = $(".thumbSlide > li:first", this).outerWidth(true),
totalWidth = imageWidth * totalImages,
visibleImages = Math.round($(".thumbSlide-wrap", this).width() / imageWidth),
visibleWidth = visibleImages * imageWidth,
stopPosition = (visibleWidth - totalWidth/countSlider);
$(".thumbSlide", this).width(totalWidth+10);
}
$(".thumbSlide-prev", this).click(function(){
var parentMove = $(this).parent().prev('.thumbSlide');
if(parentMove.position().left < 0 && !$(".thumbSlide").is(":animated")){
parentMove.animate({left : "+=" + imageWidth + "px"});
$(this).parent().find('.disable').removeClass('disable');
}else{
$(this).parent().find('.thumbSlide-prev').addClass('disable');
}
return false;
});
$(".thumbSlide-next", this).click(function(){
var parentMove = $(this).parent().prev('.thumbSlide');
if(parentMove.position().left > stopPosition && !$(".thumbSlide").is(":animated")){
parentMove.animate({left : "-=" + imageWidth + "px"});
$(this).parent().find('.disable').removeClass('disable');
}else{
$(this).parent().find('.thumbSlide-next').addClass('disable');
}
return false;
});
});
});