这是我正在使用的(非常简单的)JS代码:
$(document).ready(function() {
$(".button-list .next").click(function() {
project = $(this).parents().filter(".projektweb").eq(0);
currentimg = project.find(".images-list li.current");
nextimg = currentimg.next();
firstimg = project.find(".images-list li:first");
currentimg.removeClass("current");
if (nextimg.is("li")) nextimg.addClass("current");
else firstimg.addClass("current");
return false;
});
$(".button-list .prev").click(function() {
project = $(this).parents().filter(".projektweb").eq(0);
currentimg = project.find(".images-list li.current");
previmg = currentimg.prev();
lastimg = project.find(".images-list li:last");
currentimg.removeClass("current");
if (previmg.is("li")) previmg.addClass("current");
else lastimg.addClass("current");
return false;
});
});
这就是图像列表的HTML代码的样子:
<ul class="images-list">
<li class="current"><img src="img/1.jpg" alt="" /></li>
<li><img src="img/1b.jpg" alt="" /></li>
</ul>
<ul class="button-list"> <li><a class="button prev" href="#">←</a></li>
<li><a class="button next" href="#">→</a></li></ul>
CSS:
.images-list {
height: 460px;
list-style-type:none;
float:left;
width: 460px;
overflow:hidden;
position:relative;
}
.images-list img {
height: 460px;
width: 460px;
display:block;
}
.images-list li {
display:none;
}
.images-list li.current {
display:block;
}
我想做的是在它们出现时动画图像 - 现在它们只是出现,这是可以的,但更多的眼睛会很好。
任何人都可以帮助我吗?它甚至可以这样做吗?谢谢!
答案 0 :(得分:3)
我为你做了a demo。基本上我使用jQuery的animate()
添加了一些左右滚动动画你可以在任何方向动画图像,但如果你想获得更多花哨,那么我会像Matt建议的那样使用Cycle插件。
附加CSS
.images-list li.animating {
position: absolute;
top: 0;
left: 0;
display: block;
}
脚本
$(document).ready(function() {
// *** Constants ***
var project = $('.projektweb');
animationTime = 500, // scroll time in milliseconds
animationWidth = 480; // image width = 460 + 20px padding between images
leftPadding = parseInt( project.find('ul').css('padding-left'), 10); // padding due to UL
// *** Next image ***
$('.button-list .next').click(function() {
currentimg = project.find('li.current');
nextimg = (currentimg.next().is('li')) ? currentimg.next() : project.find('.images-list li:first');
currentimg
.removeClass('current')
.addClass('animating')
.css('left', leftPadding)
.animate({
left: '-=' + animationWidth
}, animationTime, function(){
$(this).removeClass('animating');
});
nextimg
.addClass('animating')
.css('left', (animationWidth + leftPadding) + 'px')
.animate({
left: 0 + leftPadding
}, animationTime, function(){
$(this).removeClass('animating').addClass('current');
})
return false;
});
// *** Prev image ***
$('.button-list .prev').click(function() {
currentimg = project.find('.images-list li.current');
previmg = (currentimg.prev().is("li")) ? currentimg.prev() : project.find('.images-list li:last');
currentimg
.addClass('animating')
.css('left', leftPadding)
.removeClass("current")
.animate({
left: '+=' + animationWidth
}, animationTime, function(){
$(this).removeClass('animating');
});
previmg
.addClass('animating')
.css('left', '-' + (animationWidth) + 'px')
.animate({
left: '+=' + (animationWidth + leftPadding)
}, animationTime, function(){
$(this).removeClass('animating').addClass('current');
})
return false;
});
});