0

jsFiddle

以下のコードを使用すると、jQueryコンテンツのスライドショーが機能しますが、最初または最後のスライドのいずれかで次の矢印と前の矢印が消えます。現在のスライドに応じて、スライドを最初または最後に戻します。あなたは私が言っていることを理解します。

jQuery

var currentPosition = 0;
var slideWidth = 560;
var slides = $('.slide');
var numberOfSlides = slides.length;
// Remove scrollbar in JS
$('#slidesContainer').css('overflow', 'hidden');

// Wrap all .slides with #slideInner div
slides.wrapAll('<div id="slideInner"></div>')
// Float left to display horizontally, readjust .slides width
.css({
    'float' : 'left',
    'width' : slideWidth
});

// Set #slideInner width equal to total width of all slides
$('#slideInner').css('width', slideWidth * numberOfSlides);

// Insert controls in the DOM
$('#slideshow')
    .prepend('<span class="control" id="leftControl">Clicking moves left</span>')
    .append('<span class="control" id="rightControl">Clicking moves right</span>');

// Hide left arrow control on first load
manageControls(currentPosition);

    // Create event listeners for .controls clicks
$('.control')
        .bind('click', function(){
    // Determine new position
    currentPosition = ($(this).attr('id')=='rightControl') ? currentPosition+1 : currentPosition-1;

    // Hide / show controls
    manageControls(currentPosition);
    // Move slideInner using margin-left
    $('#slideInner').animate({
        'marginLeft' : slideWidth*(-currentPosition)
    });
});

// manageControls: Hides and Shows controls depending on currentPosition
function manageControls(position){
    // Hide left arrow if position is first slide
    if(position==0){ $('#leftControl').hide() } else{ $('#leftControl').show() }
    // Hide right arrow if position is last slide
        if(position==numberOfSlides-1){ $('#rightControl').hide() } else{ $('#rightControl').show() }
}
4

1 に答える 1

1

manageControls行の代わりに関数への呼び出しを削除する必要があります

currentPosition = ($(this).attr('id')=='rightControl') ? currentPosition+1 : currentPosition-1;

コードを使用する

if(($(this).attr('id')=='rightControl')) {
    if(currentPosition == numberOfSlides-1)
        currentPosition = 0;
    else
        currentPosition++;
} else if($(this).attr('id')=='leftControl'){
    if(currentPosition == 0)
        currentPosition = numberOfSlides-1;
    else
        currentPosition--;
}

フィドルの更新バージョンについては、http://jsfiddle.net/WTvsM/1/を参照してください。

于 2013-03-26T17:00:50.370 に答える