1

我创建了一个图片库。

当我单击下一个和上一个按钮时,我将其设置为上下

当我单击上一个和下一个时,我需要它并排出现。

这是演示

http://jsfiddle.net/T657N/16/

4

2 回答 2

2

只需将top参数更改left为脚本内部。

演示在这里

于 2012-09-13T08:07:14.797 回答
1

您只需更改 JavaScript 的 SwapFirstLast() 函数:

代替

 $(this).animate({ 'top' : direction + $(this).height() + 'px' }, 'slow', function() { //animate the img above/under the gallery (assuming all pictures are equal height)
  $(this).css('z-index', newZindex) //set new z-index
    .animate({ 'top' : '0' }, 'slow', function() { //animate the image back to its original position
      inAnimation = false; //reset the flag
    });
});

 $(this).animate({ 'left' : direction + $(this).height() + 'px' }, 'slow', function() { //animate the img above/under the gallery (assuming all pictures are equal height)
  $(this).css('z-index', newZindex) //set new z-index
    .animate({ 'left' : '0' }, 'slow', function() { //animate the image back to its original position
      inAnimation = false; //reset the flag
    });
});

所以最后你的功能将是:

function swapFirstLast(isFirst) {
if(inAnimation) return false; //if already swapping pictures just return
else inAnimation = true; //set the flag that we process a image

var processZindex, direction, newZindex, inDeCrease; //change for previous or next image

if(isFirst) { processZindex = z; direction = '-'; newZindex = 1; inDeCrease = 1; } //set variables for "next" action
else { processZindex = 1; direction = ''; newZindex = z; inDeCrease = -1; } //set variables for "previous" action

$('#pictures img').each(function() { //process each image
  if($(this).css('z-index') == processZindex) { //if its the image we need to process
    $(this).animate({ 'left' : direction + $(this).height() + 'px' }, 'slow', function() { //animate the img above/under the gallery (assuming all pictures are equal height)
      $(this).css('z-index', newZindex) //set new z-index
        .animate({ 'left' : '0' }, 'slow', function() { //animate the image back to its original position
          inAnimation = false; //reset the flag
        });
    });
  } else { //not the image we need to process, only in/de-crease z-index
    $(this).animate({ 'top' : '0' }, 'slow', function() { //make sure to wait swapping the z-index when image is above/under the gallery
      $(this).css('z-index', parseInt($(this).css('z-index')) + inDeCrease); //in/de-crease the z-index by one
    });
  }
});

return false; //don't follow the clicked link

}

希望它会帮助你。

于 2012-09-13T08:05:57.127 回答